@font-face {
    font-family: 'NeueMontreal-Regular';
    src: url('../assets/fonts/NeueMontreal-Regular.ttf') format('ttf'),
         url('../assets/fonts/NeueMontreal-Regular.ttf') format('ttf');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NeueMontreal-Medium';
    src: url('../assets/fonts/NeueMontreal-Medium.ttf') format('ttf'),
         url('../assets/fonts/NeueMontreal-Medium.ttf') format('ttf');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NeueHaasDisplay-XXThin';
    src: url('../assets/fonts/NeueHaasDisplay-XXThin.woff2') format('woff2'),
         url('../assets/fonts/NeueHaasDisplay-XXThin.woff2') format('woff2');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NeueHaasDisplay-XThin';
    src: url('../assets/fonts/NeueHaasDisplay-XThin.woff2') format('woff2'),
         url('../assets/fonts/NeueHaasDisplay-XThin.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NeueHaasDisplay-Thin';
    src: url('../assets/fonts/NeueHaasDisplay-Thin.woff2') format('woff2'),
         url('../assets/fonts/NeueHaasDisplay-Thin.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

  
@font-face {
    font-family: 'NeueHaasDisplay-Roman';
    src: url('../assets/fonts/NeueHaasDisplay-Roman.woff2') format('woff2'),
         url('../assets/fonts/NeueHaasDisplay-Roman.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'NeueHaasDisplay-Mediu';
    src: url('../assets/fonts/NeueHaasDisplay-Mediu.woff2') format('woff2'),
         url('../assets/fonts/NeueHaasDisplay-Mediu.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

 
@font-face {
    font-family: 'BetterGrade-519DV';
    src: url('../assets/fonts/BetterGrade-519DV.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Notera2PersonalUseOnlyLight-maBV';
    src: url('../assets/fonts/Notera2PersonalUseOnlyLight-maBV.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'PodluxHarmocastRegular-V4JJw';
    src: url('../assets/fonts/PodluxHarmocastRegular-V4JJw.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
 
@font-face {
    font-family: 'AmsterdamHandwriting';
    src: url('../assets/fonts/AmsterdamHandwriting.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Hijrnotes';
    src: url('../assets/fonts/Hijrnotes.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'OceanTracePersonalUse-1joPg';
    src: url('../assets/fonts/OceanTracePersonalUse-1joPg.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

.OceanTracePersonalUse-1joPg {
    font-family: 'OceanTracePersonalUse-1joPg', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}
  

.BetterGrade-519DV {
    font-family: 'BetterGrade-519DV', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}
  
.Notera2PersonalUseOnlyLight-maBV {
    font-family: 'Notera2PersonalUseOnlyLight-maBV', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}

.PodluxHarmocastRegular-V4JJw {
    font-family: 'PodluxHarmocastRegular-V4JJw', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}

.AmsterdamHandwriting {
    font-family: 'AmsterdamHandwriting', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}

.Hijrnotes {
    font-family: 'Hijrnotes', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}
/* ----------------------------------------------------
   2. EXPLICIT FONT UTILITY CLASSES
---------------------------------------------------- */

.NeueMontreal-Regular {
    font-family: 'NeueMontreal-Regular', sans-serif !important;
    font-weight: 400;
    font-style: normal;
}

.NeueMontreal-Medium {
    font-family: 'NeueMontreal-Medium', sans-serif !important;
    font-weight: 500;
    font-style: normal;
}

.NeueHaasDisplay-XXThin {
    font-family: 'NeueHaasDisplay-XXThin', sans-serif !important;
    font-weight: 100;
    font-style: normal;
}

.NeueHaasDisplay-XThin {
    font-family: 'NeueHaasDisplay-XThin', sans-serif !important;
    font-weight: 100;
    font-style: normal;
}

.NeueHaasDisplay-Thin {
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-weight: 100;
    font-style: normal;
}

.NeueHaasDisplay-Roman {
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-weight: normal;
    font-style: normal;
}

.NeueHaasDisplay-Mediu {
    font-family: 'NeueHaasDisplay-Mediu', sans-serif !important;
    font-weight: normal;
    font-style: normal;
}

:root {
    --primary-black: #030303;
    --soft-black: #0b0b0b;
    --primary-orange: #ff6a00;
    --glow-orange: #ff8a1f;
    --white: #f5f5f5;
    --muted-text: #707070;
    --grid-line: rgba(3, 3, 3, .055);
    --max-width: 1440px;
    --header-height: 82px;
    --ease: cubic-bezier(.22, 1, .36, 1);
}

* {
    box-sizing: border-box;
}

html {
    min-width: 320px;
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    margin: 0;
    color: var(--primary-black);
    font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background:
        linear-gradient(var(--grid-line) 1px, transparent 1px),
        linear-gradient(90deg, var(--grid-line) 1px, transparent 1px),
        var(--white);
    background-size: 40px 40px;
    overflow-x: hidden;
    cursor: auto;
}

a {
    color: inherit;
    text-decoration: none;
}

button {
    font: inherit;
}

.site-shell {
    min-height: 100vh;
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
}

.site-shell::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(440px circle at var(--cursor-x, 62%) var(--cursor-y, 40%), rgba(255, 106, 0, .105), transparent 62%),
        radial-gradient(280px circle at var(--cursor-x, 62%) var(--cursor-y, 40%), rgba(255, 255, 255, .68), transparent 70%);
    mix-blend-mode: multiply;
    opacity: .7;
    transition: opacity .35s var(--ease);
}

.lux-cursor,
.cursor-aura {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 10001;
    pointer-events: none;
    border-radius: 50%;
    opacity: 0;
    transform: translate3d(-50%, -50%, 0);
}

.lux-cursor {
    width: 9px;
    height: 9px;
    background: var(--primary-orange);
    box-shadow: 0 0 22px rgba(255, 106, 0, .55);
    transition: width .24s var(--ease), height .24s var(--ease), opacity .24s var(--ease), background .24s var(--ease);
}

.cursor-aura {
    width: 42px;
    height: 42px;
    border: 1px solid rgba(3, 3, 3, .18);
    background: rgba(255, 255, 255, .28);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(3px);
    box-shadow: 0 18px 42px rgba(0, 0, 0, .08);
    transition: width .3s var(--ease), height .3s var(--ease), opacity .24s var(--ease), border-color .24s var(--ease), background .24s var(--ease);
}

.cursor-ready .lux-cursor,
.cursor-ready .cursor-aura {
    opacity: 1;
}

.cursor-hover .lux-cursor {
    width: 6px;
    height: 6px;
    background: #fff;
}

.cursor-hover .cursor-aura {
    width: 66px;
    height: 66px;
    border-color: rgba(255, 106, 0, .42);
    background: rgba(255, 106, 0, .1);
}

@media (hover: hover) and (pointer: fine) {
    html.cursor-enhanced body,
    html.cursor-enhanced a,
    html.cursor-enhanced button {
        cursor: none;
    }
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    border-bottom: 1px solid rgba(3, 3, 3, .06);
    background:
        linear-gradient(90deg, rgba(245, 245, 245, .88), rgba(245, 245, 245, .66) 48%, rgba(245, 245, 245, .9)),
        rgba(245, 245, 245, .72);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
    transition: box-shadow .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease);
}

.site-header.is-scrolled {
    border-color: rgba(3, 3, 3, .09);
    background:
        linear-gradient(90deg, rgba(245, 245, 245, .94), rgba(245, 245, 245, .76) 48%, rgba(245, 245, 245, .94)),
        rgba(245, 245, 245, .82);
    box-shadow: 0 18px 55px rgba(0, 0, 0, .065);
}

.header-inner {
    width: min(100%, calc(var(--max-width) + 112px));
    min-height: var(--header-height);
    margin: 0 auto;
    padding: 9px 56px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: clamp(28px, 4vw, 68px);
}

.brand-mark {
    display: inline-flex;
    align-items: center;
    width: auto;
    height: 58px;
}

.brand-mark img {
    display: block;
    width: auto;
    height: 100%;
    object-fit: contain;
}

.primary-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border: 1px solid rgba(3, 3, 3, .075);
    border-radius: 999px;
    background: rgba(255, 255, 255, .32);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .78);
    gap: clamp(20px, 2.8vw, 38px);
}

.primary-nav a {
    position: relative;
    padding: 11px 2px;
    color: rgba(3, 3, 3, .62);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .11em;
    text-transform: uppercase;
    transition: color .25s var(--ease);
}

.primary-nav a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 5px;
    height: 1px;
    background: var(--primary-orange);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform .28s var(--ease);
}

.primary-nav a:hover {
    color: var(--primary-black);
}

.primary-nav a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
}

.nav-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: clamp(16px, 2.2vw, 30px);
}

.proposal-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    padding: 12px 0 16px;
    font-size: clamp(15px, 1.05vw, 18px);
    font-weight: 900;
    letter-spacing: .035em;
    text-transform: uppercase;
}

.proposal-link::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 5px;
    height: 9px;
    background: url("data:image/svg+xml,%3Csvg width='190' height='10' viewBox='0 0 190 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 5.2C32 1.4 63 9.4 95 5.2C127 1.1 158 8 189 4' stroke='%23030303' stroke-width='2.2' stroke-linecap='round'/%3E%3Cpath d='M4 7.5C36 3.8 67 7.8 99 7.1C129 6.4 160 2.8 186 6.2' stroke='%23030303' stroke-width='1.4' stroke-linecap='round'/%3E%3C/svg%3E") center / 100% 100% no-repeat;
    transform-origin: left center;
    transition: transform .35s var(--ease);
}

.proposal-link:hover::after {
    transform: scaleX(1.06);
}

.menu-button {
    width: 54px;
    height: 54px;
    border: 0;
    border-radius: 50%;
    background: var(--primary-orange);
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 9px;
    cursor: pointer;
    box-shadow: 0 18px 40px rgba(255, 106, 0, .22);
    transition: transform .35s var(--ease), background .35s var(--ease), box-shadow .35s var(--ease);
}

.menu-button span {
    width: 25px;
    height: 2px;
    border-radius: 99px;
    background: #fff;
    transition: transform .35s var(--ease);
}

.menu-button:hover {
    transform: scale(1.05);
    background: var(--glow-orange);
    box-shadow: 0 22px 52px rgba(255, 106, 0, .3);
}

.menu-button[aria-expanded="true"] span:first-child {
    transform: translateY(5.5px) rotate(45deg);
}

.menu-button[aria-expanded="true"] span:last-child {
    transform: translateY(-5.5px) rotate(-45deg);
}

.menu-panel {
    position: absolute;
    right: max(24px, calc((100vw - var(--max-width)) / 2 + 56px));
    top: 70px;
    width: min(300px, calc(100vw - 48px));
    padding: 18px;
    border: 1px solid rgba(3, 3, 3, .11);
    border-radius: 18px;
    background: rgba(245, 245, 245, .9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow: 0 30px 90px rgba(0, 0, 0, .12);
    display: grid;
    gap: 8px;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-10px);
    transition: opacity .3s var(--ease), transform .3s var(--ease);
}

.menu-panel.is-open {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.menu-panel a {
    padding: 13px 14px;
    border-radius: 10px;
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .06em;
}

.menu-panel a:hover {
    color: #fff;
    background: var(--soft-black);
}

.hero {
    width: min(100%, var(--max-width));
    min-height: calc(100svh - var(--header-height));
    margin: 0 auto;
    padding: clamp(28px, 3.8vw, 54px) 56px 0;
    display: grid;
    grid-template-columns: minmax(0, 2.9fr) minmax(420px, 0.1fr);
    align-items: end;
    gap: clamp(32px, 4vw, 68px);
    position: relative;
    z-index: 1;
}

.hero-copy {
    max-width: 660px;
    align-self: center;
    padding-bottom: clamp(26px, 4.4vw, 62px);
}

.eyebrow {
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    margin: 0 0 18px;
    color: var(--primary-orange);
    font-size: 14px;
    /* font-weight: 900; */
    letter-spacing: 1.2px;
    text-transform: uppercase;
}

.copy-slider {
    position: relative;
    min-height: clamp(250px, 28vw, 340px);
}

.copy-slide {
    position: absolute;
    inset: 0 auto auto 0;
    width: min(100%, 660px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    filter: blur(8px);
    transition: opacity .75s var(--ease), transform .75s var(--ease), filter .75s var(--ease), visibility .75s var(--ease);
}

.copy-slide.is-active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    filter: blur(0);
    z-index: 2;
}

.copy-slide.is-leaving {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    filter: blur(0);
    z-index: 1;
}

.copy-slide h1,
.copy-slide h2 {
    width: max-content;
    max-width: 100%;
    min-height: 1.96em;
    margin: 0;
    color: var(--primary-black);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(5rem, 5vw, 5rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: -1.8px;
}

.copy-slide h1 span,
.copy-slide h2 span {
    display: block;
    white-space: nowrap;
    clip-path: inset(100% 0 0 0);
    transform: translateY(30px) scale(.985);
    transform-origin: left bottom;
    opacity: 0;
}

.copy-slide.is-active h1 span,
.copy-slide.is-active h2 span {
    animation: titleLineIn .88s var(--ease) forwards;
}

.copy-slide.is-active h1 span:nth-child(2),
.copy-slide.is-active h2 span:nth-child(2) {
    animation-delay: .09s;
}

.copy-slide.is-leaving h1 span,
.copy-slide.is-leaving h2 span {
    animation: titleLineOut .48s var(--ease) forwards;
}

.copy-slide .hero-text {
    opacity: 0;
    transform: translateY(12px);
    filter: blur(8px);
}

.copy-slide.is-active .hero-text {
    animation: textIn .72s .22s var(--ease) forwards;
}

.copy-slide.is-leaving .hero-text {
    animation: textOut .34s var(--ease) forwards;
}

.hero-text {
    max-width: 610px;
    min-height: 84px;
    margin: 24px 0 0;
    color: #000000;
    font-size: clamp(.98rem, 1vw, 1.08rem);
    line-height: 1.68;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
}

.hero-text strong {
    color: var(--primary-black);
    font-weight: 900;
}

.slide-dots {
    display: flex;
    align-items: center;
    gap: 10px;
    height: 16px;
    margin-top: 4px;
}

.slide-dots button {
    width: 8px;
    height: 8px;
    padding: 0;
    border: 0;
    border-radius: 99px;
    background: rgba(3, 3, 3, .2);
    cursor: pointer;
    transition: width .3s var(--ease), background .3s var(--ease);
}

.slide-dots button.is-active {
    width: 34px;
    background: var(--primary-orange);
}

.cta-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 20px;
    margin-top: 24px;
}

.button {
    min-height: 50px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 15px 28px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .8px;
    text-transform: uppercase;
    transition: transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), box-shadow .4s var(--ease);
    font-family: 'NeueHaasDisplay-Mediu', sans-serif !important;
}

.button-primary {
    color: #fff;
    background: var(--primary-orange);
    border: 1px solid var(--primary-orange);
    box-shadow: 0 16px 34px rgba(255, 106, 0, .14);
}

.button-primary:hover,
.button-primary:focus-visible {
    background: var(--glow-orange);
    border-color: var(--glow-orange);
    transform: translateY(-3px);
    box-shadow: 0 0 40px rgba(255, 106, 0, .3);
}

.button-secondary {
    border: 1px solid var(--primary-black);
    background: rgba(245, 245, 245, .35);
    color: var(--primary-black);
}

.button-secondary:hover,
.button-secondary:focus-visible {
    background: var(--primary-black);
    color: #fff;
    transform: translateY(-3px);
}

.hero-mascot {
    align-self: stretch;
    min-height: 0;
    height: min(760px, calc(100svh - var(--header-height) - 6px));
    display: flex;
    align-items: flex-end;
    justify-content: center;
    position: relative;
    /* overflow: hidden; */
    isolation: isolate;
    --mascot-frame-x: 0px;
    --mascot-img-x: 0px;
    --mascot-img-y: 0px;
    --mascot-scroll: 0px;
    --mascot-scale: 1;
    --mascot-tilt: 0deg;
}

.hero-mascot::before {
    content: "";
    position: absolute;
    inset: 4% -2% 0;
    border: 1px solid rgba(3, 3, 3, .08);
    border-radius: 50%;
    background:
        radial-gradient(circle at 54% 37%, rgba(255, 138, 31, .22), transparent 46%),
        radial-gradient(circle at 50% 55%, rgba(255, 255, 255, .74), transparent 64%);
    filter: blur(.2px);
    z-index: -1;
    transform: translateY(calc(var(--mascot-scroll) * -.22));
    transition: transform .2s ease-out;
}

.hero-mascot::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: min(74%, 560px);
    height: 34px;
    border-radius: 50%;
    background: radial-gradient(closest-side, rgba(3, 3, 3, .2), transparent);
    transform: translateX(-50%);
    opacity: .32;
    filter: blur(5px);
    z-index: -1;
}

.mascot-frame {
    width: min(112%, 900px);
    height: 100%;
    min-height: 0;
    display: flex;
    align-items: flex-end;
    justify-content: end;
    /* overflow: hidden; */
    position: relative;
    transform: translate3d(var(--mascot-frame-x), 0, 0) scale(var(--mascot-scale));
    transform-origin: 50% 100%;
    transition: transform .18s ease-out;
}

.mascot-frame::before,
.mascot-frame::after {
    content: "";
    position: absolute;
    pointer-events: none;
    z-index: 0;
}

.mascot-frame::before {
    width: 42%;
    aspect-ratio: 1;
    right: 18%;
    top: 7%;
    border-radius: 50%;
    background:
        radial-gradient(circle at 48% 48%, rgba(255, 255, 255, .72), transparent 36%),
        radial-gradient(circle at 50% 50%, rgba(255, 106, 0, .28), transparent 68%);
    filter: blur(24px);
    opacity: .76;
    transform: translate3d(calc(var(--mascot-frame-x) * -.35), calc(var(--mascot-scroll) * -.18), 0);
}

.mascot-frame::after {
    width: min(32%, 250px);
    aspect-ratio: 1;
    right: 17%;
    top: 9%;
    border: 1px solid rgba(255, 106, 0, .2);
    border-left-color: transparent;
    border-bottom-color: transparent;
    border-radius: 50%;
    opacity: .72;
    transform: rotate(calc(-18deg + var(--mascot-tilt)));
}

.mascot-frame img {
    position: relative;
    z-index: 1;
    width: auto;
    max-width: none;
    height: 124%;
    object-fit: contain;
    object-position: center bottom;
    filter:
        drop-shadow(0 34px 45px rgba(0, 0, 0, .22))
        drop-shadow(0 0 30px rgba(255, 106, 0, .12));
    transform: translate(calc(1% + var(--mascot-img-x)), calc(14% + var(--mascot-img-y) + var(--mascot-scroll))) rotate(var(--mascot-tilt));
    transform-origin: 50% 100%;
    transition: transform .18s ease-out, filter .35s var(--ease);
}

.reveal {
    opacity: 0;
}

.is-loaded .reveal-copy {
    animation: copyIn 1s var(--ease) forwards;
}

.is-loaded .reveal-art {
    animation: artIn 1s .1s var(--ease) forwards;
}

@keyframes copyIn {
    from {
        opacity: 0;
        transform: translateY(34px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes artIn {
    from {
        opacity: 0;
        transform: scale(.97) translateY(20px);
    }
    to {
        opacity: 1;
        transform: scale(1) translateY(0);
    }
}

@keyframes titleLineIn {
    from {
        clip-path: inset(100% 0 0 0);
        opacity: 0;
        transform: translateY(30px) scale(.985);
        filter: blur(12px);
    }
    58% {
        filter: blur(0);
    }
    to {
        clip-path: inset(0 0 0 0);
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@keyframes titleLineOut {
    from {
        clip-path: inset(0 0 0 0);
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
    to {
        clip-path: inset(0 0 100% 0);
        opacity: 0;
        transform: translateY(-18px) scale(.99);
        filter: blur(9px);
    }
}

@keyframes textIn {
    from {
        opacity: 0;
        transform: translateY(12px);
        filter: blur(8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@keyframes textOut {
    from {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
    to {
        opacity: 0;
        transform: translateY(-8px);
        filter: blur(8px);
    }
}

@media (max-width: 1180px) {
    :root {
        --header-height: 78px;
    }

    .header-inner {
        min-height: var(--header-height);
        padding: 12px 34px;
    }

    .brand-mark {
        height: 54px;
    }

    .primary-nav {
        gap: 20px;
    }

    .hero {
        min-height: auto;
        padding: 70px 34px 64px;
        grid-template-columns: 1fr;
        gap: 58px;
    }

    .hero-copy {
        max-width: 760px;
    }

    .copy-slide {
        width: min(100%, 760px);
    }

    .copy-slide h1,
    .copy-slide h2 {
        font-size: clamp(3rem, 6.8vw, 4.8rem);
    }

    .hero-mascot {
        height: min(690px, calc(100svh - var(--header-height) - 70px));
        width: min(860px, 100%);
        margin: 0 auto;
    }

    .mascot-frame {
        height: 100%;
    }
}

@media (max-width: 980px) {
    .primary-nav {
        display: none;
    }

    .header-inner {
        grid-template-columns: auto auto;
        justify-content: space-between;
    }
}

@media (max-width: 760px) {
    :root {
        --header-height: 72px;
    }

    .header-inner {
        min-height: var(--header-height);
        padding: 11px 22px;
    }

    .brand-mark {
        height: 48px;
    }

    .proposal-link {
        display: none;
    }

    .menu-button {
        width: 54px;
        height: 54px;
    }

    .menu-panel {
        top: 70px;
        right: 22px;
    }

    .hero {
        padding: 34px 22px 44px;
        gap: 42px;
    }

    .eyebrow {
        margin-bottom: 16px;
        font-size: 11px;
        line-height: 1.45;
    }

    .copy-slider {
        min-height: 270px;
    }

    .copy-slide h1,
    .copy-slide h2 {
        font-size: clamp(2.1rem, 9.8vw, 3.2rem);
        line-height: 1;
        letter-spacing: 0;
    }

    .hero-text {
        min-height: 118px;
        margin-top: 18px;
        font-size: .98rem;
        line-height: 1.68;
    }

    .slide-dots {
        margin-top: 0;
    }

    .cta-row {
        display: grid;
        gap: 14px;
        margin-top: 22px;
    }

    .button {
        width: 100%;
        min-height: 54px;
        padding: 16px 18px;
        font-size: 14px;
    }

    .hero-mascot {
        height: 500px;
    }

    .mascot-frame {
        width: 100%;
        height: 100%;
    }

    .mascot-frame img {
        max-width: none;
        height: 116%;
        transform: translate(calc(1% + var(--mascot-img-x)), calc(12% + var(--mascot-img-y) + var(--mascot-scroll))) rotate(var(--mascot-tilt));
    }
}

@media (max-width: 430px) {
    .copy-slider {
        min-height: 292px;
    }

    .hero-text {
        min-height: 148px;
    }

    .hero-mascot {
        height: 430px;
    }

    .mascot-frame {
        height: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: .001ms !important;
        animation-duration: .001ms !important;
        animation-iteration-count: 1 !important;
    }
}


/* tech logo / integrated ecosystem */

#dm-integration-hero {
    position: relative;
    padding: clamp(160px, 12vh, 140px) clamp(24px, 5vw, 56px);
    overflow: hidden;
    background:
        radial-gradient(ellipse 62% 48% at 50% 52%, rgba(255, 106, 0, .07) 0%, transparent 68%),
        linear-gradient(180deg, #fdfdfd 0%, #fbfbfb 48%, #f9f8f7 100%);
    color: var(--primary-black);
}

.dm-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.dm-bg-glow {
    position: absolute;
    width: min(72vw, 760px);
    height: min(48vw, 500px);
    left: 50%;
    top: 54%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 106, 0, .15) 0%, rgba(255, 120, 40, .06) 42%, transparent 72%);
    filter: blur(90px);
    opacity: .8;
}

.dm-bg-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(255, 106, 0, 0.028) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 106, 0, 0.028) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: radial-gradient(ellipse 90% 80% at 50% 42%, #000 25%, transparent 100%);
    opacity: .55;
}

.dm-container {
    position: relative;
    width: min(100%, 1680px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 2;
}

.dm-head {
    width: 100%;
    max-width: min(100%, 980px);
    margin: 0 auto;
}

.dm-badge {
    display: inline-block;
    margin: 0 0 18px;
    padding: 0;
    border: none;
    background: none;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1.2px;
    line-height: 1.2;
    text-transform: uppercase;
    color: var(--primary-orange);
}

.dm-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2rem, 3.6vw, 3.75rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: -1.2px;
    text-transform: Capitalize;
    color: var(--primary-black);
    white-space: nowrap;
}

.dm-subtitle {
    max-width: 610px;
    margin: clamp(18px, 2.5vh, 24px) auto 0;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.98rem, 1vw, 1.08rem);
    font-weight: 400;
    line-height: 1.68;
    letter-spacing: 0.2px;
    color: #000;
}

.dm-carousel-wrapper {
    width: 100%;
    margin-top: clamp(48px, 6vh, 72px);
    display: flex;
    flex-direction: column;
    gap: clamp(1.5rem, 2.5vh, 2rem);
    position: relative;
    overflow: hidden;
    -webkit-mask-image: linear-gradient(
        to right,
        transparent 0%,
        #000 clamp(2.5rem, 7vw, 5.5rem),
        #000 calc(100% - clamp(2.5rem, 7vw, 5.5rem)),
        transparent 100%
    );
    mask-image: linear-gradient(
        to right,
        transparent 0%,
        #000 clamp(2.5rem, 7vw, 5.5rem),
        #000 calc(100% - clamp(2.5rem, 7vw, 5.5rem)),
        transparent 100%
    );
}

.dm-marquee-track {
    display: flex;
    width: max-content;
    position: relative;
}

.dm-marquee-group {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    padding-right: 2.5rem;
    will-change: transform;
    backface-visibility: hidden;
}

.dm-marquee-group > * {
    margin-right: 2.5rem;
}

.dm-scroll-left {
    animation: dm-marquee-l-axis 22s linear infinite;
}

.dm-scroll-right {
    animation: dm-marquee-r-axis 22s linear infinite;
}

.dm-marquee-track:hover .dm-marquee-group {
    animation-play-state: paused;
}

@keyframes dm-marquee-l-axis {
    0% { transform: translate3d(0, 0, 0); }
    100% { transform: translate3d(-100%, 0, 0); }
}

@keyframes dm-marquee-r-axis {
    0% { transform: translate3d(-100%, 0, 0); }
    100% { transform: translate3d(0, 0, 0); }
}

.dm-icon-box {
    width: 4.25rem;
    height: 4.25rem;
    flex-shrink: 0;
    border-radius: 9999px;
    background: #fff;
    border: 1px solid rgba(0, 0, 0, 0.04);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.03);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.dm-icon-box:hover {
    transform: scale(1.08);
    border-color: rgba(255, 106, 0, 0.3);
}

.dm-icon-box img {
    width: 2.25rem;
    height: 2.25rem;
    object-fit: contain;
}

.dm-cta-wrap {
    display: flex;
    justify-content: center;
    width: 100%;
    margin-top: clamp(48px, 6vh, 72px);
}

@media (max-width: 768px) {
    #dm-integration-hero {
        padding: clamp(72px, 10vh, 96px) clamp(20px, 5vw, 28px);
    }

    .dm-title {
        font-size: clamp(1.65rem, 6.5vw, 2.25rem);
        letter-spacing: 0.03em;
        white-space: normal;
    }

    .dm-subtitle {
        font-size: clamp(0.92rem, 3.6vw, 1rem);
        line-height: 1.62;
        letter-spacing: 0.025em;
    }

    .dm-carousel-wrapper {
        margin-top: clamp(36px, 5vh, 48px);
        gap: 1.25rem;
    }

    .dm-marquee-group > * {
        margin-right: 1.75rem;
    }

    .dm-marquee-group {
        padding-right: 1.75rem;
    }

    .dm-icon-box {
        width: 3.75rem;
        height: 3.75rem;
    }

    .dm-icon-box img {
        width: 1.9rem;
        height: 1.9rem;
    }

    .dm-cta-wrap {
        margin-top: clamp(36px, 5vh, 48px);
    }

    .dm-cta-wrap .icb-ind-cta {
        min-width: min(100%, 280px);
        width: 100%;
        max-width: 320px;
    }
}

@media (max-width: 480px) {
    .dm-title {
        font-size: clamp(1.45rem, 7.5vw, 1.85rem);
    }
}

/* blog / insights */

.icb-insights {
    --ins-ease: cubic-bezier(.22, 1, .36, 1);
    position: relative;
    padding: clamp(80px, 10vh, 120px) clamp(24px, 5vw, 56px);
    overflow: hidden;
    background:
        radial-gradient(ellipse 62% 48% at 50% 52%, rgba(255, 106, 0, .07) 0%, transparent 68%),
        linear-gradient(180deg, #fdfdfd 0%, #fbfbfb 48%, #f9f8f7 100%);
    color: var(--primary-black);
    scroll-margin-top: var(--header-height);
}

.icb-ins-svg-defs {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
}

.icb-insights-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.icb-insights-glow {
    position: absolute;
    width: min(72vw, 760px);
    height: min(48vw, 500px);
    left: 50%;
    top: 54%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 106, 0, .14) 0%, rgba(255, 120, 40, .05) 42%, transparent 72%);
    filter: blur(90px);
    opacity: .75;
}

.icb-insights-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(255, 106, 0, .028) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(255, 106, 0, .028) 1px, transparent 1px);
    background-size: 44px 44px;
    mask-image: radial-gradient(ellipse 90% 80% at 50% 42%, #000 25%, transparent 100%);
    opacity: .5;
}

.icb-insights-wrap {
    position: relative;
    z-index: 2;
    width: min(100%, 1680px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 2.8vh, 32px);
}

.icb-insights-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 420px);
    gap: clamp(20px, 3vw, 40px);
    align-items: end;
    width: 100%;
}

.icb-insights-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 10px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 1.2px;
    line-height: 1.2;
    text-transform: uppercase;
    color: var(--muted-text);
}

.icb-insights-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary-orange);
    box-shadow: 0 0 12px rgba(255, 106, 0, .55);
    flex-shrink: 0;
}

.icb-insights-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2rem, 3.6vw, 3.75rem);
    font-weight: 400;
    line-height: 1.06;
    letter-spacing: -1.2px;
    color: var(--primary-black);
}

.icb-insights-desc {
    margin: 0;
    max-width: 420px;
    justify-self: end;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.94rem, 1vw, 1.05rem);
    font-weight: 300;
    line-height: 1.68;
    letter-spacing: 1.2px;
    color: var(--muted-text);
}

.icb-insights-body {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: clamp(12px, 1.6vh, 18px);
}

.icb-insights-stage {
    position: relative;
    width: 100%;
}

.icb-ins-nav {
    position: absolute;
    top: 50%;
    z-index: 8;
    flex-shrink: 0;
    width: clamp(42px, 4vw, 48px);
    height: clamp(42px, 4vw, 48px);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(3, 3, 3, .12);
    border-radius: 50%;
    background: rgba(255, 255, 255, .94);
    color: var(--primary-black);
    cursor: pointer;
    backdrop-filter: blur(10px);
    transform: translateY(-50%);
    box-shadow:
        0 6px 20px rgba(3, 3, 3, .07),
        inset 0 1px 0 rgba(255, 255, 255, .98);
    transition:
        transform .35s var(--ins-ease),
        border-color .35s var(--ins-ease),
        background .35s var(--ins-ease),
        box-shadow .35s var(--ins-ease),
        color .35s var(--ins-ease);
}

.icb-ins-nav--prev {
    left: clamp(0px, 0.2vw, 4px);
}

.icb-ins-nav--next {
    right: clamp(0px, 0.2vw, 4px);
}

.icb-ins-nav svg {
    width: 18px;
    height: 18px;
}

.icb-ins-nav:hover,
.icb-ins-nav:focus-visible {
    border-color: rgba(255, 106, 0, .4);
    background: #fff;
    color: var(--primary-orange);
    transform: translateY(-50%) scale(1.05);
    box-shadow:
        0 10px 28px rgba(255, 106, 0, .12),
        0 0 0 3px rgba(255, 106, 0, .07);
}

.icb-ins-carousel {
    --ins-radius: clamp(18px, 1.6vw, 24px);
    --ins-step: 14.5cqw;
    --ins-step-far: 27.5cqw;
    position: relative;
    width: 100%;
    height: clamp(300px, 20vw, 370px);
    padding-inline: clamp(24px, 2.8vw, 36px);
    perspective: 1800px;
    container-type: inline-size;
    overflow: visible;
}

.icb-ins-track {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: visible;
}

.icb-ins-card {
    --ins-tilt-x: 0deg;
    --ins-tilt-y: 0deg;
    --ins-lift: 0px;
    position: absolute;
    top: 50%;
    left: 50%;
    width: clamp(300px, 31cqw, 440px);
    height: 100%;
    max-height: clamp(300px, 20vw, 370px);
    margin: 0;
    transform-origin: center center;
    transform-style: preserve-3d;
    transition:
        transform .9s var(--ins-ease),
        opacity .9s var(--ins-ease),
        filter .9s var(--ins-ease);
    opacity: 0;
    pointer-events: none;
    z-index: 1;
    will-change: transform, opacity;
}

.icb-ins-card-shell {
    position: relative;
    width: 100%;
    height: 100%;
    padding: 2px;
    border-radius: var(--ins-radius);
    overflow: hidden;
    isolation: isolate;
    background: transparent;
}

.icb-ins-card-runborder {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    z-index: 3;
    opacity: 0;
    visibility: hidden;
}

.icb-ins-card.is-active:not(.is-sliding) .icb-ins-card-runborder {
    opacity: 1;
    visibility: visible;
}

.icb-insights-stage.is-sliding .icb-ins-card-runborder {
    opacity: 0 !important;
    visibility: hidden !important;
}

.icb-ins-card-runborder svg {
    display: block;
    width: 100%;
    height: 100%;
}

.icb-ins-card-ring {
    fill: none;
    stroke: url(#icbInsBorderGrad);
    stroke-width: 2.2;
    vector-effect: non-scaling-stroke;
    stroke-dasharray: 14 86;
    stroke-linecap: round;
    animation: icbInsRingRun 4.2s linear infinite;
}

@keyframes icbInsRingRun {
    to { stroke-dashoffset: -100; }
}

.icb-ins-card.is-ready {
    opacity: 1;
}

.icb-ins-card.is-hidden {
    opacity: 0 !important;
    pointer-events: none !important;
    z-index: 0 !important;
}

.icb-ins-card.is-far-prev {
    z-index: 1;
    opacity: .44;
    filter: brightness(.9) saturate(.92);
    transform: translate(calc(-50% - var(--ins-step-far)), -50%) scale(.84) rotateY(10deg);
    pointer-events: auto;
}

.icb-ins-card.is-prev {
    z-index: 3;
    opacity: .88;
    filter: brightness(.97) saturate(.97);
    transform: translate(calc(-50% - var(--ins-step)), -50%) scale(.91) rotateY(5deg);
    pointer-events: auto;
}

.icb-ins-card.is-active {
    z-index: 5;
    opacity: 1;
    filter: none;
    transform: translate(-50%, calc(-50% - var(--ins-lift))) scale(1) rotateY(0deg) rotateX(var(--ins-tilt-x)) rotateY(var(--ins-tilt-y));
    pointer-events: auto;
}

.icb-ins-card.is-next {
    z-index: 3;
    opacity: .88;
    filter: brightness(.97) saturate(.97);
    transform: translate(calc(-50% + var(--ins-step)), -50%) scale(.91) rotateY(-5deg);
    pointer-events: auto;
}

.icb-ins-card.is-far-next {
    z-index: 1;
    opacity: .44;
    filter: brightness(.9) saturate(.92);
    transform: translate(calc(-50% + var(--ins-step-far)), -50%) scale(.84) rotateY(-10deg);
    pointer-events: auto;
}

.icb-ins-card.is-active.is-wobble {
    animation: icbInsWobble .55s var(--ins-ease);
}

@keyframes icbInsWobble {
    0%, 100% { transform: translate(-50%, calc(-50% - var(--ins-lift))) scale(1) rotateY(0deg) rotateX(var(--ins-tilt-x)) rotateY(var(--ins-tilt-y)); }
    25% { transform: translate(-50%, calc(-50% - var(--ins-lift))) scale(1.015) rotateY(-2.5deg) rotateX(calc(var(--ins-tilt-x) + 1.5deg)) rotateY(calc(var(--ins-tilt-y) - 1deg)); }
    75% { transform: translate(-50%, calc(-50% - var(--ins-lift))) scale(1.015) rotateY(2.5deg) rotateX(calc(var(--ins-tilt-x) - 1deg)) rotateY(calc(var(--ins-tilt-y) + 1.5deg)); }
}

.icb-ins-card-link {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    border-radius: calc(var(--ins-radius) - 2px);
    overflow: hidden;
    background: #0a0a0a;
    border: 1px solid rgba(255, 255, 255, .08);
    box-shadow:
        0 18px 44px rgba(3, 3, 3, .14),
        inset 0 1px 0 rgba(255, 255, 255, .05);
    transition:
        box-shadow .5s var(--ins-ease),
        border-color .5s var(--ins-ease);
}

.icb-ins-card.is-active:not(.is-sliding) .icb-ins-card-link {
    border-color: rgba(255, 255, 255, .06);
    box-shadow:
        0 26px 60px rgba(3, 3, 3, .2),
        0 12px 36px rgba(255, 106, 0, .1),
        inset 0 1px 0 rgba(255, 255, 255, .08);
}

.icb-ins-card.is-active.is-hovered {
    --ins-lift: 6px;
}

.icb-ins-card.is-active.is-hovered .icb-ins-card-link {
    box-shadow:
        0 32px 72px rgba(3, 3, 3, .22),
        0 16px 44px rgba(255, 106, 0, .16),
        inset 0 1px 0 rgba(255, 255, 255, .1);
}

.icb-ins-card-media {
    position: absolute;
    inset: 0;
    overflow: hidden;
    background:
        linear-gradient(145deg, #0a0a0a 0%, #1a0c02 42%, #3d1a00 100%);
}

.icb-ins-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: scale(1.02);
    transition: transform .8s var(--ins-ease);
    filter: saturate(.88) contrast(1.04) brightness(.94);
}

.icb-ins-card-media::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, rgba(255, 106, 0, .18) 0%, transparent 42%),
        linear-gradient(180deg, transparent 30%, rgba(3, 3, 3, .15) 100%);
    z-index: 1;
    pointer-events: none;
    mix-blend-mode: soft-light;
}

.icb-ins-card.is-active.is-hovered .icb-ins-card-media img {
    transform: scale(1.08);
}

.icb-ins-card-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(3, 3, 3, .06) 0%, rgba(3, 3, 3, .12) 38%, rgba(3, 3, 3, .78) 100%);
    pointer-events: none;
    transition: opacity .9s var(--ins-ease);
}

.icb-ins-card:not(.is-active) .icb-ins-card-media::after {
    opacity: .72;
}

.icb-ins-card-shine {
    position: absolute;
    inset: 0;
    background: linear-gradient(125deg, transparent 35%, rgba(255, 255, 255, .12) 50%, transparent 65%);
    transform: translateX(-120%);
    transition: transform .9s var(--ins-ease);
    pointer-events: none;
    z-index: 1;
}

.icb-ins-card.is-active.is-hovered .icb-ins-card-shine {
    transform: translateX(120%);
}

.icb-ins-card-body {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    padding: clamp(20px, 2.5vw, 28px);
}

.icb-ins-card-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 11px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    line-height: 1.2;
}

.icb-ins-card-cat {
    color: var(--primary-orange);
}

.icb-ins-card-sep {
    width: 1px;
    height: 10px;
    background: rgba(255, 255, 255, .28);
}

.icb-ins-card-time {
    color: rgba(255, 255, 255, .72);
}

.icb-ins-card-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(1.15rem, 1.6vw, 1.45rem);
    font-weight: 400;
    line-height: 1.22;
    letter-spacing: -.02em;
    color: #fff;
}

.icb-ins-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    margin-top: 0;
}

.icb-ins-dot-btn {
    width: 8px;
    height: 8px;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: rgba(3, 3, 3, .14);
    cursor: pointer;
    transition:
        width .45s var(--ins-ease),
        background .35s var(--ins-ease),
        transform .35s var(--ins-ease);
}

.icb-ins-dot-btn.is-active {
    width: 28px;
    background: var(--primary-orange);
    box-shadow: 0 0 16px rgba(255, 106, 0, .35);
}

.icb-ins-dot-btn:hover,
.icb-ins-dot-btn:focus-visible {
    background: rgba(255, 106, 0, .45);
    transform: scale(1.08);
}

.icb-ins-reveal {
    opacity: 0;
    transform: translateY(28px);
    filter: blur(6px);
}

.icb-ins-reveal.is-visible {
    animation: icbInsIn .9s var(--ins-ease) forwards;
}

.icb-ins-reveal[data-delay="1"].is-visible { animation-delay: .1s; }
.icb-ins-reveal[data-delay="2"].is-visible { animation-delay: .22s; }
.icb-ins-reveal[data-delay="3"].is-visible { animation-delay: .34s; }

@keyframes icbInsIn {
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@media (max-width: 1024px) {
    .icb-insights-head {
        grid-template-columns: 1fr;
        gap: 14px;
        align-items: start;
    }

    .icb-insights-desc {
        justify-self: start;
        max-width: 560px;
    }

    .icb-ins-carousel {
        --ins-step: 15.5cqw;
        --ins-step-far: 29cqw;
        height: clamp(290px, 34vw, 360px);
    }

    .icb-ins-card {
        width: clamp(280px, 33cqw, 380px);
        max-height: clamp(290px, 34vw, 360px);
    }
}

@media (max-width: 820px) {
    .icb-ins-carousel {
        --ins-step: 17cqw;
        --ins-step-far: 31cqw;
    }

    .icb-ins-card.is-far-prev,
    .icb-ins-card.is-far-next {
        opacity: .32 !important;
        transform: translate(calc(-50% - var(--ins-step-far)), -50%) scale(.78) rotateY(8deg);
    }

    .icb-ins-card.is-far-next {
        transform: translate(calc(-50% + var(--ins-step-far)), -50%) scale(.78) rotateY(-8deg);
    }
}

@media (max-width: 680px) {
    .icb-ins-card.is-far-prev,
    .icb-ins-card.is-far-next {
        opacity: 0 !important;
        pointer-events: none !important;
        z-index: 0 !important;
    }

    .icb-ins-card.is-prev {
        transform: translate(calc(-50% - var(--ins-step)), -50%) scale(.88) rotateY(5deg);
    }

    .icb-ins-card.is-next {
        transform: translate(calc(-50% + var(--ins-step)), -50%) scale(.88) rotateY(-5deg);
    }
}

@media (max-width: 768px) {
    .icb-insights {
        padding: clamp(56px, 8vh, 80px) clamp(20px, 5vw, 28px);
    }

    .icb-insights-title {
        font-size: clamp(1.65rem, 6vw, 2.1rem);
        letter-spacing: -.04em;
    }

    .icb-insights-desc {
        font-size: clamp(.9rem, 3.5vw, 1rem);
        letter-spacing: .03em;
    }

    .icb-insights-stage {
        gap: 8px;
    }

    .icb-ins-nav {
        width: 40px;
        height: 40px;
    }

    .icb-insights-wrap {
        gap: clamp(14px, 2vh, 22px);
    }

    .icb-ins-carousel {
        --ins-step: 19cqw;
        height: clamp(280px, 72vw, 340px);
    }

    .icb-ins-card {
        width: clamp(260px, 72vw, 320px);
        max-height: clamp(280px, 72vw, 340px);
    }

    .icb-ins-card.is-prev {
        transform: translate(calc(-50% - var(--ins-step)), -50%) scale(.86) rotateY(4deg);
        opacity: .72;
    }

    .icb-ins-card.is-next {
        transform: translate(calc(-50% + var(--ins-step)), -50%) scale(.86) rotateY(-4deg);
        opacity: .72;
    }
}

@media (max-width: 520px) {
    .icb-ins-nav {
        width: 38px;
        height: 38px;
    }

    .icb-ins-nav svg {
        width: 16px;
        height: 16px;
    }

    .icb-ins-carousel {
        --ins-step: clamp(100px, 22vw, 130px);
    }

    .icb-ins-card.is-far-prev,
    .icb-ins-card.is-far-next {
        opacity: 0 !important;
        pointer-events: none !important;
    }

    .icb-ins-card.is-prev,
    .icb-ins-card.is-next {
        opacity: .42;
        filter: brightness(.88) saturate(.9);
        pointer-events: none;
    }

    .icb-ins-card.is-active {
        transform: translate(-50%, -50%) scale(1) rotateY(0deg) rotateX(var(--ins-tilt-x)) rotateY(var(--ins-tilt-y));
    }
}

@media (prefers-reduced-motion: reduce) {
    .icb-ins-card,
    .icb-ins-card-link,
    .icb-ins-card-media img,
    .icb-ins-card-shine,
    .icb-ins-card-runborder,
    .icb-ins-card-ring,
    .icb-ins-nav,
    .icb-ins-dot-btn,
    .icb-ins-reveal,
    .icb-ins-reveal.is-visible {
        transition: none !important;
        animation: none !important;
    }

    .icb-ins-reveal {
        opacity: 1;
        transform: none;
        filter: none;
    }
}

/* tech logo */

/* testimonials */
#icb-testimonials {
    position: relative;
    padding:
        clamp(112px, calc(10vh + 40px), 152px)
        clamp(24px, 5vw, 48px)
        clamp(112px, calc(10vh + 40px), 152px);
    overflow: hidden;
    background-color: #fbfbfb;
    color: var(--primary-black);
    scroll-margin-top: var(--header-height);
}

#icb-testimonials .icb-bg-grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(to right, rgba(3, 3, 3, .028) 1px, transparent 1px),
        linear-gradient(to bottom, rgba(3, 3, 3, .028) 1px, transparent 1px);
    background-size: 56px 56px;
    z-index: 1;
    pointer-events: none;
}

#icb-testimonials .icb-container {
    position: relative;
    width: min(100%, 1680px);
    margin: 0 auto;
    z-index: 2;
}

#icb-testimonials .icb-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: min(100%, 760px);
    margin: 0 auto clamp(36px, 5vh, 56px);
    gap: 0;
}

#icb-testimonials .icb-badge {
    display: inline-block;
    margin: 0 0 18px;
    padding: 0;
    border: none;
    background: none;
    border-radius: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1.2px;
    line-height: 1.2;
    text-transform: uppercase;
    color: var(--primary-orange);
}

#icb-testimonials .icb-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(5rem, 5vw, 5rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: -1.8px;
    color: var(--primary-black);
    text-transform: capitalize;
}

#icb-testimonials .icb-subtitle {
    max-width: 610px;
    margin: 24px 0 0;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.98rem, 1vw, 1.08rem);
    font-weight: 400;
    line-height: 1.68;
    letter-spacing: normal;
    color: #000000;
}

  /* --- ANTI-STUTTER 4-COLUMN VERTICAL ENGINE --- */
  #icb-testimonials .icb-testimonials-grid {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
    height: 700px;
    overflow: hidden;
    position: relative;
    width: 100%;
    margin: 0 auto;
  }

  #icb-testimonials .icb-column {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 20rem;
    position: relative;
  }

  /* Structural Responsive Column Controls */
  #icb-testimonials .icb-col-2,
  #icb-testimonials .icb-col-3,
  #icb-testimonials .icb-col-4 {
    display: none;
  }

  #icb-testimonials .icb-track {
    display: flex;
    flex-direction: column;
    height: max-content;
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }

  /* Structural gap configuration for seamless looping math */
  #icb-testimonials .icb-track-group {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding-bottom: 1.5rem;
  }

  /* Varied multi-track marquee speeds */
  #icb-testimonials .icb-scroll-col1 { animation: icb-vertical-loop 14s linear infinite; }
  #icb-testimonials .icb-scroll-col2 { animation: icb-vertical-loop 20s linear infinite; }
  #icb-testimonials .icb-scroll-col3 { animation: icb-vertical-loop 16.5s linear infinite; }
  #icb-testimonials .icb-scroll-col4 { animation: icb-vertical-loop 22s linear infinite; }

  #icb-testimonials .icb-testimonials-grid:hover .icb-track {
    animation-play-state: paused;
  }

  @keyframes icb-vertical-loop {
    0% { transform: translate3d(0, 0, 0); }
    100% { transform: translate3d(0, -50%, 0); }
  }

  /* Testimonial Card Styling */
  #icb-testimonials .icb-card {
    box-sizing: border-box;
    background-color: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 24px;
    padding: 2.25rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.02);
    transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
  }

  #icb-testimonials .icb-card:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 102, 0, 0.15);
    box-shadow: 0 12px 35px rgba(255, 102, 0, 0.05);
  }

  #icb-testimonials .icb-card-text {
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(0.88rem, 0.92vw, 0.98rem);
    font-weight: 400;
    line-height: 1.65;
    letter-spacing: 0.01em;
    color: rgba(3, 3, 3, .78);
    margin: 0 0 1.5rem 0;
  }

  #icb-testimonials .icb-user-block {
    display: flex;
    align-items: center;
    gap: 0.85rem;
  }

  #icb-testimonials .icb-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 9999px;
    object-fit: cover;
    background-color: #eee;
  }

  #icb-testimonials .icb-user-info {
    display: flex;
    flex-direction: column;
  }

  #icb-testimonials .icb-user-name {
    font-family: 'NeueHaasDisplay-Mediu', sans-serif !important;
    font-size: clamp(0.82rem, 0.88vw, 0.92rem);
    font-weight: 700;
    letter-spacing: 0.03em;
    line-height: 1.35;
    color: var(--primary-black);
  }

  #icb-testimonials .icb-user-role {
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(0.72rem, 0.78vw, 0.82rem);
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.35;
    color: rgba(3, 3, 3, .52);
    margin-top: 0.12rem;
  }

  #icb-testimonials .icb-fade-top,
  #icb-testimonials .icb-fade-bottom {
    position: absolute;
    left: 0;
    right: 0;
    height: 7.5rem;
    pointer-events: none;
    z-index: 5;
  }

  #icb-testimonials .icb-fade-top {
    top: 0;
    background: linear-gradient(to bottom, #fbfbfb 15%, transparent);
  }

  #icb-testimonials .icb-fade-bottom {
    bottom: 0;
    background: linear-gradient(to top, #fbfbfb 15%, transparent);
  }

  /* Responsive Multi-Column Breakpoints */
  @media (min-width: 640px) {
    #icb-testimonials .icb-col-2 { display: flex; }
  }

  @media (min-width: 1024px) {
    #icb-testimonials .icb-col-3 { display: flex; }
  }

  @media (min-width: 1280px) {
    #icb-testimonials .icb-col-4 { display: flex; }
  }

  @media (max-width: 1100px) {
    #icb-testimonials .icb-title {
        font-size: clamp(3rem, 6.8vw, 4.8rem);
    }
  }

  @media (max-width: 760px) {
    #icb-testimonials .icb-badge {
        margin-bottom: 16px;
        font-size: 11px;
        line-height: 1.45;
    }

    #icb-testimonials .icb-title {
        font-size: clamp(2.1rem, 9.8vw, 3.2rem);
        line-height: 1;
        letter-spacing: 0;
    }

    #icb-testimonials .icb-subtitle {
        margin-top: 18px;
        font-size: .98rem;
    }
  }
/* testimonials */

/* how we work — premium static glass cards */

.icb-process {
    --proc-ease: cubic-bezier(.22, 1, .36, 1);
    --proc-orange: #ff6a00;
    --proc-orange-soft: rgba(255, 106, 0, .45);
    --proc-glass: rgba(18, 14, 12, .72);
    --proc-border: rgba(255, 106, 0, .32);
    --proc-gap: clamp(20px, 2.2vw, 30px);
    --proc-pad-y: clamp(80px, 10vh, 120px);
    --proc-pad-x: clamp(24px, 5vw, 56px);
    position: relative;
    width: 100%;
    background:
        radial-gradient(ellipse 90% 60% at 15% 0%, rgba(255, 106, 0, .14) 0%, transparent 55%),
        radial-gradient(ellipse 70% 50% at 85% 100%, rgba(255, 80, 0, .1) 0%, transparent 50%),
        linear-gradient(168deg, #121010 0%, #060504 42%, #0a0705 68%, #030201 100%);
    color: #f5f5f5;
    scroll-margin-top: var(--header-height);
    overflow: hidden;
    padding: var(--proc-pad-y) var(--proc-pad-x);
}

.icb-process-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
}

.icb-process-bg-glow {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: .55;
}

.icb-process-bg-glow--a {
    width: min(55vw, 640px);
    height: min(55vw, 640px);
    left: -8%;
    top: 8%;
    background: radial-gradient(circle, rgba(255, 106, 0, .22) 0%, transparent 68%);
}

.icb-process-bg-glow--b {
    width: min(45vw, 520px);
    height: min(45vw, 520px);
    right: -6%;
    bottom: 12%;
    background: radial-gradient(circle, rgba(255, 72, 0, .16) 0%, transparent 70%);
}

.icb-process-bg-glow--c {
    width: min(38vw, 440px);
    height: min(22vw, 260px);
    left: 38%;
    top: 42%;
    background: radial-gradient(circle, rgba(255, 120, 40, .1) 0%, transparent 72%);
    filter: blur(100px);
}

.icb-process-bg-grid {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(255, 106, 0, .035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 106, 0, .035) 1px, transparent 1px);
    background-size: 72px 72px;
    mask-image: radial-gradient(ellipse 85% 75% at 50% 45%, #000 20%, transparent 100%);
    opacity: .45;
}

.icb-process-pin {
    position: relative;
    width: 100%;
    z-index: 1;
}

.icb-process-stage {
    position: relative;
    z-index: 1;
    width: min(100%, 1680px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: clamp(18px, 2.8vh, 28px);
}

/* header */
.icb-process-head {
    flex-shrink: 0;
    max-width: 720px;
    padding: 0;
}

.icb-process-eyebrow-row {
    display: flex;
    align-items: center;
    gap: clamp(12px, 2vw, 20px);
    margin-bottom: clamp(14px, 2vh, 20px);
}

.icb-process-eyebrow {
    flex-shrink: 0;
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(11px, 0.85vw, 13px);
    font-weight: 500;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--proc-orange);
}

.icb-process-eyebrow-line {
    position: relative;
    flex: 1;
    max-width: 120px;
    height: 1px;
    background: linear-gradient(90deg, rgba(255, 106, 0, .55), rgba(255, 106, 0, .15));
}

.icb-process-eyebrow-dot {
    position: absolute;
    top: 50%;
    right: 0;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--proc-orange);
    box-shadow: 0 0 12px 3px rgba(255, 106, 0, .75);
    transform: translate(50%, -50%);
}

.icb-process-heading {
    margin: 0 0 clamp(8px, 1vh, 12px);
    color: #fff;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(5rem, 5vw, 5rem);
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: -1.8px;
    white-space: nowrap;
}

.icb-process-title-line {
    display: inline;
}

.icb-process-title-line--accent {
    color: var(--proc-orange);
}

.icb-process-sub {
    max-width: 610px;
    margin: clamp(16px, 2vh, 24px) 0 0;
    color: rgba(255, 255, 255, .78);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: 18px;
    font-weight: 300;
    line-height: 1.2;
    letter-spacing: 1.3px;
}

/* track */
.icb-process-viewport {
    width: 100%;
    overflow: visible;
}

.icb-process-track {
    position: relative;
    display: flex;
    align-items: stretch;
    gap: 0;
    width: 100%;
    padding-top: clamp(48px, 5.5vw, 64px);
}

.icb-process-spine {
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 1px;
    transform: translateY(-50%) scaleX(.6);
    background: linear-gradient(90deg, transparent 2%, rgba(255, 106, 0, .18) 8%, rgba(255, 106, 0, .28) 50%, rgba(255, 106, 0, .18) 92%, transparent 98%);
    pointer-events: none;
    z-index: 0;
    opacity: 0;
    transition: opacity .8s var(--proc-ease), transform 1s var(--proc-ease);
}

.icb-process-spine.is-visible {
    opacity: 1;
    transform: translateY(-50%) scaleX(1);
}

/* cards */
.icb-process-card {
    --proc-tilt-x: 0deg;
    --proc-tilt-y: 0deg;
    --proc-enter-delay: 0s;
    position: relative;
    z-index: 1;
    flex: 1 1 0;
    min-width: 0;
    min-height: clamp(240px, 24vw, 320px);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: clamp(14px, 1.3vw, 18px);
    border-radius: 10px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, .06) 0%, rgba(255, 255, 255, .015) 28%, rgba(0, 0, 0, .25) 100%),
        var(--proc-glass);
    border: 1px solid var(--proc-border);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    box-shadow:
        0 20px 40px rgba(0, 0, 0, .5),
        inset 0 1px 0 rgba(255, 255, 255, .07);
    opacity: 0;
    transform: perspective(900px) rotateX(var(--proc-tilt-x)) rotateY(var(--proc-tilt-y)) translateY(22px) scale(.985);
    transition:
        transform .6s var(--proc-ease),
        border-color .45s var(--proc-ease),
        box-shadow .45s var(--proc-ease),
        opacity .6s var(--proc-ease);
    cursor: default;
    outline: none;
}

.icb-process-card.is-visible {
    animation: icbProcCardEnter .75s var(--proc-ease) var(--proc-enter-delay) forwards;
}

.icb-process-card[data-step="1"] { --proc-enter-delay: .28s; }
.icb-process-card[data-step="2"] { --proc-enter-delay: .36s; }
.icb-process-card[data-step="3"] { --proc-enter-delay: .44s; }
.icb-process-card[data-step="4"] { --proc-enter-delay: .52s; }
.icb-process-card[data-step="5"] { --proc-enter-delay: .6s; }

@keyframes icbProcCardEnter {
    to {
        opacity: 1;
        transform: perspective(900px) rotateX(var(--proc-tilt-x)) rotateY(var(--proc-tilt-y)) translateY(0) scale(1);
    }
}

.icb-process-card.is-visible .icb-process-card-glow {
    animation: icbProcGlowEnter .65s var(--proc-ease) calc(var(--proc-enter-delay) + .12s) forwards;
}

@keyframes icbProcGlowEnter {
    from {
        opacity: 0;
        transform: scaleX(.35);
    }
    to {
        opacity: .92;
        transform: scaleX(1);
    }
}

.icb-process-card.is-hovered,
.icb-process-card:focus-visible,
.icb-process-card.is-visible.is-hovered,
.icb-process-card.is-visible:focus-visible {
    border-color: rgba(255, 106, 0, .55);
    box-shadow:
        0 32px 64px rgba(0, 0, 0, .55),
        0 0 40px rgba(255, 106, 0, .12),
        inset 0 1px 0 rgba(255, 255, 255, .1);
    transform: perspective(900px) rotateX(var(--proc-tilt-x)) rotateY(var(--proc-tilt-y)) translateY(-5px) scale(1);
}

.icb-process-card-glow {
    position: absolute;
    top: -1px;
    left: 18%;
    right: 18%;
    height: 2px;
    border-radius: 2px;
    background: linear-gradient(90deg, transparent 0%, rgba(255, 106, 0, .4) 25%, #ff9a4d 50%, rgba(255, 106, 0, .4) 75%, transparent 100%);
    box-shadow:
        0 0 20px 3px rgba(255, 106, 0, .6),
        0 -10px 36px rgba(255, 106, 0, .28);
    opacity: 0;
    transform-origin: center;
    transform: scaleX(.35);
    transition: opacity .4s var(--proc-ease), box-shadow .4s var(--proc-ease), transform .4s var(--proc-ease);
    pointer-events: none;
}

.icb-process-card.is-hovered .icb-process-card-glow,
.icb-process-card:focus-visible .icb-process-card-glow,
.icb-process-card.is-active .icb-process-card-glow {
    opacity: 1;
    box-shadow:
        0 0 28px 4px rgba(255, 106, 0, .75),
        0 -12px 40px rgba(255, 106, 0, .35);
}

.icb-process-card-step {
    position: absolute;
    top: clamp(12px, 1.1vw, 16px);
    right: clamp(12px, 1.1vw, 16px);
    z-index: 2;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(1.5rem, 1.75vw, 1.95rem);
    font-weight: 300;
    letter-spacing: normal;
    line-height: 1;
    color: rgba(255, 106, 0, .72);
}

.icb-process-card-body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: clamp(12px, 1.2vh, 16px);
    width: 100%;
    margin-top: auto;
}

.icb-process-card-icon {
    width: clamp(46px, 4vw, 62px);
    height: clamp(46px, 4vw, 62px);
    color: var(--proc-orange);
    flex-shrink: 0;
}

.icb-process-card-icon svg {
    width: 100%;
    height: 100%;
}

.icb-proc-draw {
    stroke: currentColor;
    stroke-width: 1.75;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    stroke-dasharray: 120;
    stroke-dashoffset: 120;
}

.icb-process-card.is-visible .icb-proc-draw {
    animation: icbProcDraw .85s var(--proc-ease) forwards;
}

@keyframes icbProcDraw {
    to { stroke-dashoffset: 0; }
}

.icb-process-card-title {
    margin: 0;
    padding-right: clamp(32px, 3vw, 44px);
    color: #fff;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2.25rem, 2.85vw, 3.35rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: normal;
}

.icb-process-card-text {
    margin: 0;
    max-width: 32ch;
    color: rgba(255, 255, 255, .52);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.95rem, .98vw, 1.08rem);
    font-weight: 300;
    line-height: 1.54;
    letter-spacing: 1.1px;
}

/* equal gaps */
.icb-process-gap {
    position: relative;
    flex: 0 0 var(--proc-gap);
    align-self: stretch;
    z-index: 1;
}

.icb-process-gap::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 1px;
    background: linear-gradient(90deg, rgba(255, 106, 0, .2), rgba(255, 106, 0, .55) 50%, rgba(255, 106, 0, .2));
    opacity: 0;
    transform: scaleX(0);
    transform-origin: center;
    transition: opacity .45s var(--proc-ease), transform .55s var(--proc-ease);
}

.icb-process-gap.is-visible::before {
    opacity: 1;
    transform: scaleX(1);
}

.icb-process-gap--mascot {
    overflow: visible;
}

/* mascot — static on card tops */
.icb-process-mascot-slot {
    position: absolute;
    left: 50%;
    top: 0;
    z-index: 6;
    width: clamp(200px, 20vw, 300px);
    pointer-events: none;
    opacity: 0;
    transform: translate(-50%, calc(-100% + 20px));
    transition: opacity .7s var(--proc-ease) .5s, transform .7s var(--proc-ease) .5s;
}

.icb-process-gap--mascot.is-visible .icb-process-mascot-slot {
    opacity: 1;
    transform: translate(-50%, calc(-100% + 20px));
}

.icb-process-mascot {
    display: block;
    width: 100%;
    height: auto;
    object-fit: contain;
    filter:
        drop-shadow(0 10px 24px rgba(0, 0, 0, .55))
        drop-shadow(0 0 28px rgba(255, 106, 0, .28));
}

/* reveal */
.icb-proc-reveal {
    opacity: 0;
    transform: translateY(24px);
    filter: blur(8px);
}

.icb-proc-reveal.is-visible {
    animation: icbProcReveal .9s var(--proc-ease) forwards;
}

.icb-proc-reveal[data-delay="1"].is-visible { animation-delay: .08s; }
.icb-proc-reveal[data-delay="2"].is-visible { animation-delay: .16s; }
.icb-proc-reveal[data-delay="3"].is-visible { animation-delay: .24s; }

@keyframes icbProcReveal {
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

/* mobile */
@media (max-width: 1100px) {
    .icb-process-heading {
        font-size: clamp(3rem, 5.5vw, 4.25rem);
        letter-spacing: -1.2px;
    }

    .icb-process-card-title {
        font-size: clamp(1.65rem, 2.4vw, 2.35rem);
        letter-spacing: normal;
    }

    .icb-process-card-step {
        font-size: clamp(1.25rem, 1.5vw, 1.55rem);
    }

    .icb-process-card {
        padding: clamp(12px, 1.2vw, 16px);
    }

    .icb-process-card-icon {
        width: clamp(40px, 3.6vw, 52px);
        height: clamp(40px, 3.6vw, 52px);
    }
}

@media (max-width: 900px) {
    .icb-process {
        --proc-pad-y: clamp(64px, 9vh, 88px);
        --proc-gap: clamp(14px, 3vw, 20px);
    }

    .icb-process-stage {
        gap: clamp(16px, 2.5vh, 24px);
    }

    .icb-process-heading {
        font-size: clamp(2.25rem, 8vw, 3rem);
        letter-spacing: -.8px;
        white-space: normal;
    }

    .icb-process-sub {
        font-size: clamp(.92rem, 3.6vw, 1rem);
        line-height: 1.62;
        letter-spacing: normal;
    }

    .icb-process-card-title {
        font-size: clamp(1.45rem, 4.5vw, 1.85rem);
        letter-spacing: normal;
    }

    .icb-process-card-text {
        font-size: clamp(.88rem, 3.2vw, .98rem);
        letter-spacing: normal;
    }

    .icb-process-card-step {
        font-size: clamp(1.15rem, 4vw, 1.35rem);
    }

    .icb-process-track {
        flex-wrap: wrap;
        justify-content: center;
        gap: var(--proc-gap);
        row-gap: clamp(16px, 3vw, 22px);
        padding-top: clamp(56px, 14vw, 80px);
    }

    .icb-process-spine {
        display: none;
    }

    .icb-process-card {
        flex: 1 1 calc(50% - var(--proc-gap));
        min-width: calc(50% - var(--proc-gap));
        max-width: calc(50% - var(--proc-gap));
        min-height: auto;
    }

    .icb-process-gap:not(.icb-process-gap--mascot) {
        display: none;
    }

    .icb-process-gap--mascot {
        flex: 0 0 100%;
        order: -1;
        height: 0;
        min-height: 0;
    }

    .icb-process-gap--mascot::before {
        display: none;
    }

    .icb-process-mascot-slot {
        width: clamp(160px, 42vw, 220px);
        top: auto;
        bottom: 0;
        transform: translate(-50%, 0);
    }

    .icb-process-gap--mascot.is-visible .icb-process-mascot-slot {
        transform: translate(-50%, 0);
    }
}

@media (max-width: 520px) {
    .icb-process-card {
        flex: 1 1 100%;
        min-width: 100%;
        max-width: 100%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .icb-proc-reveal,
    .icb-proc-reveal.is-visible {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .icb-process-card,
    .icb-process-card.is-visible,
    .icb-process-card.is-hovered,
    .icb-process-card:focus-visible {
        animation: none !important;
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
    }

    .icb-process-card.is-visible .icb-process-card-glow {
        animation: none !important;
        opacity: .92 !important;
        transform: scaleX(1) !important;
    }

    .icb-process-gap::before,
    .icb-process-spine,
    .icb-process-mascot-slot {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }

    .icb-process-gap--mascot.is-visible .icb-process-mascot-slot {
        transform: translate(-50%, calc(-100% + 20px)) !important;
    }

    .icb-process-spine.is-visible {
        transform: translateY(-50%) scaleX(1) !important;
    }

    .icb-process-card.is-visible .icb-proc-draw {
        animation: none !important;
        stroke-dashoffset: 0 !important;
    }
}

/* process end */

/* projects — left editorial / right mockup */

.luxury-showcase {
    --lf-accent: var(--primary-orange, #ff6a00);
    --lf-ease: cubic-bezier(.22, 1, .36, 1);
    --lf-gap: clamp(24px, 3vh, 36px);
    --lf-case-gap: clamp(8px, 1vh, 12px);
    --lf-title-size: clamp(5rem, 5vw, 5rem);
    --lf-title-ls: -1.8px;
    --lf-tab-size: clamp(0.76rem, 0.88vw, 0.86rem);
    --lf-tab-icon: clamp(19px, 1.45vw, 22px);
    --lf-case-title: clamp(1.65rem, 2.15vw, 2.2rem);
    --lf-case-meta: clamp(0.92rem, 0.96vw, 1rem);
    --lf-case-desc: clamp(0.88rem, 0.92vw, 0.96rem);
    --lf-cta-size: clamp(0.72rem, 0.78vw, 0.8rem);
    --lf-index-size: clamp(0.88rem, 0.94vw, 0.98rem);
    --lf-content-w: clamp(380px, 32vw, 460px);
    position: relative;
    width: 100%;
    height: calc(100svh - var(--header-height));
    min-height: calc(112svh - var(--header-height));
    max-height: calc(112svh - var(--header-height));
    padding: clamp(36px, 4.5vh, 56px) clamp(20px, 3.5vw, 48px);
    box-sizing: border-box;
    overflow: hidden;
    scroll-margin-top: var(--header-height);
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(255, 106, 0, .03), transparent 70%),
        linear-gradient(rgba(3, 3, 3, .022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(3, 3, 3, .022) 1px, transparent 1px),
        #f7f7f7;
    background-size: auto, 56px 56px, 56px 56px, auto;
    padding-top: 60px;
padding-bottom: 60px;
}

.lf-shell {
    width: min(100%, 1680px);
    height: 100%;
    margin: 0 auto;
}

.lf-theater {
    height: 100%;
    padding: clamp(48px, 5.5vh, 72px) clamp(32px, 3.5vw, 52px);
    border: 1px solid rgba(255, 255, 255, .7);
    border-radius: clamp(24px, 2.5vw, 36px);
    background: rgba(255, 255, 255, .62);
    backdrop-filter: blur(24px);
    box-shadow:
        0 20px 56px rgba(0, 0, 0, .045),
        inset 0 1px 0 rgba(255, 255, 255, .95);
    box-sizing: border-box;
}

.lf-master-grid {
    display: grid;
    grid-template-columns: minmax(0, 38fr) minmax(0, 62fr);
    gap: clamp(44px, 5vw, 80px);
    height: 100%;
    align-items: stretch;
}

.lf-col {
    min-width: 0;
    position: relative;
}

/* ── left stack ── */
.lf-col--left {
    display: flex;
    flex-direction: column;
    height: 100%;
    gap: var(--lf-gap);
    z-index: 2;
}

.lf-header {
    flex: 0 0 auto;
    text-align: left;
    display: block;
    padding: 0;
    margin: 0;
}

.lf-eyebrow {
    margin: 0 0 18px;
}

.lf-heading {
    margin: 0;
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 68px;
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: var(--lf-title-ls);
    max-width: 11ch;
}

.lf-device-row {
    flex: 0 0 auto;
    margin: 0;
    width: 100%;
    max-width: var(--lf-content-w);
    overflow: visible;
    position: relative;
    z-index: 3;
}

.lf-device-row::-webkit-scrollbar {
    display: none;
}

.lf-device-switch {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    width: 100%;
    gap: clamp(6px, 0.8vw, 10px);
    padding: 8px;
    border-radius: 14px;
    border: 1px solid rgba(255, 106, 0, .16);
    background: rgba(255, 255, 255, .85);
    box-shadow: 0 2px 12px rgba(255, 106, 0, .05);
    box-sizing: border-box;
}

.lf-device-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: clamp(6px, 0.8vw, 10px);
    flex: 1 1 0;
    min-width: 0;
    min-height: clamp(46px, 4.5vh, 52px);
    padding: 0 clamp(8px, 1vw, 14px);
    border: 1px solid transparent;
    border-radius: 10px;
    background: transparent;
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: var(--lf-tab-size);
    letter-spacing: .08em;
    text-transform: uppercase;
    cursor: pointer;
    white-space: nowrap;
    transition: color .35s ease, background .35s ease, border-color .35s ease,
        box-shadow .35s ease, transform .35s var(--lf-ease);
}

.lf-device-btn-icon {
    display: grid;
    place-items: center;
    width: var(--lf-tab-icon);
    height: var(--lf-tab-icon);
    flex-shrink: 0;
}

.lf-device-btn-icon svg {
    width: var(--lf-tab-icon);
    height: var(--lf-tab-icon);
    stroke: currentColor;
}

.lf-device-btn.is-active {
    color: var(--lf-accent);
    background: rgba(255, 106, 0, .1);
    border-color: rgba(255, 106, 0, .32);
    box-shadow: 0 4px 16px rgba(255, 106, 0, .12);
}

.lf-device-btn:hover:not(.is-active) {
    background: rgba(3, 3, 3, .035);
}

.lf-device-btn-label {
    white-space: nowrap;
}

.lf-col--left .lf-col--info {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: var(--lf-case-gap);
    max-width: var(--lf-content-w);
    width: 100%;
    min-height: 0;
    padding: 0;
    margin: 0;
    position: relative;
    z-index: 1;
    animation: none;
    margin-top: 40px;
}

.lf-project-category {
    margin: 0;
    color: var(--lf-accent);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.72rem, 0.78vw, 0.82rem);
    letter-spacing: .1em;
    text-transform: uppercase;
    transition: opacity .45s var(--lf-ease), transform .45s var(--lf-ease);
}

.lf-project-title {
    margin: 0;
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: var(--lf-case-title);
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.08;
    transition: opacity .45s var(--lf-ease), transform .45s var(--lf-ease);
}

.lf-project-meta {
    margin: 0;
    color: #030303;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size:16px;
    line-height: 1.5;
    transition: opacity .45s var(--lf-ease) .04s, transform .45s var(--lf-ease) .04s;
    letter-spacing: 1.1px;
    font-weight: 300;
}

.lf-project-desc {
    margin: 0;
    color: #030303;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: 18px;
    line-height: 1.3;
    max-width: 36ch;
    transition: opacity .45s var(--lf-ease) .08s, transform .45s var(--lf-ease) .08s;
    margin-bottom:30px;
}

.lf-theater.is-switching .lf-project-category,
.lf-theater.is-switching .lf-project-title,
.lf-theater.is-switching .lf-project-meta,
.lf-theater.is-switching .lf-project-desc {
    opacity: 0;
    transform: translateY(6px);
}

.lf-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: clamp(4px, 0.6vh, 8px) 0 0;
    padding: 6px 0;
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: var(--lf-cta-size);
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    position: relative;
    transition: color .3s ease, gap .3s ease;
}

.lf-cta::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 4px;
    width: 100%;
    height: 1px;
    background: currentColor;
    transform: scaleX(.4);
    transform-origin: left center;
    transition: transform .4s var(--lf-ease);
}

.lf-cta svg {
    width: 16px;
    height: 16px;
    stroke: currentColor;
    transition: transform .35s var(--lf-ease);
}

.lf-cta:hover {
    color: var(--lf-accent);
    gap: 12px;
}

.lf-cta:hover::after {
    transform: scaleX(1);
}

.lf-cta:hover svg {
    transform: translateX(3px);
}

.lf-controls-bar {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: clamp(12px, 1.4vw, 16px);
    width: 100%;
    max-width: var(--lf-content-w);
    margin-top: auto;
    padding-top: clamp(16px, 2vh, 24px);
    border-top: 1px solid rgba(3, 3, 3, .07);
    position: relative;
    z-index: 3;
}

.lf-nav {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    flex-shrink: 0;
    width: clamp(42px, 3.8vw, 46px);
    height: clamp(42px, 3.8vw, 46px);
    border: 1px solid rgba(3, 3, 3, .1);
    border-radius: 50%;
    background: rgba(255, 255, 255, .92);
    color: var(--primary-black, #030303);
    display: grid;
    place-items: center;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(0, 0, 0, .06);
    transform: none;
    transition: color .3s ease, border-color .3s ease, box-shadow .3s ease, transform .3s var(--lf-ease);
}

.lf-nav svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
}

.lf-nav:hover {
    color: var(--lf-accent);
    border-color: rgba(255, 106, 0, .3);
    box-shadow: 0 6px 20px rgba(255, 106, 0, .12);
    transform: scale(1.05);
}

.lf-nav:active {
    transform: scale(.96);
}

.lf-meta-progress {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
    min-width: 0;
    margin: 0;
}

.lf-index,
.lf-index-total {
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: var(--lf-index-size);
    letter-spacing: .06em;
    line-height: 1;
    flex-shrink: 0;
}

.lf-index {
    color: var(--lf-accent);
}

.lf-index-total {
    color: #030303;
}

.lf-progress {
    flex: 1;
    height: 3px;
    background: rgba(3, 3, 3, .1);
    border-radius: 3px;
    overflow: hidden;
}

.lf-progress-bar {
    width: 100%;
    height: 100%;
    background: var(--lf-accent);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform .12s linear;
}

/* ── right mockup ── */
.lf-col--mockup {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    height: 100%;
    min-height: 0;
}

.lf-mockup-scene {
    position: relative;
    width: 100%;
    height: 100%;
    min-height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    perspective: 1200px;
}

.lf-mockup-glow {
    position: absolute;
    inset: 15% 10%;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 106, 0, .08), transparent 70%);
    filter: blur(32px);
    pointer-events: none;
    z-index: 0;
}

.lf-mockup-well {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    min-height: 100%;
    max-height: none;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    overflow: hidden;
    padding: 0;
    touch-action: pan-y;
    cursor: grab;
}

.lf-mockup-well:active {
    cursor: grabbing;
}

.lf-device {
    height: 100%;
    width: 100%;
    min-height: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

.lf-device-inner {
    position: relative;
    height: 100%;
    width: auto;
    max-height: 100%;
    max-width: 100%;
    min-height: 0;
    aspect-ratio: var(--lf-device-ratio, 1214 / 704);
    --lf-tilt-x: 0deg;
    --lf-tilt-y: 0deg;
    --lf-scale: 0.9;
    transform-origin: right bottom;
    transform: rotateX(var(--lf-tilt-x)) rotateY(var(--lf-tilt-y)) scale(var(--lf-scale));
    transform-style: preserve-3d;
    transition: aspect-ratio .5s var(--lf-ease), transform .6s var(--lf-ease);
}

.lf-mockup-scene:hover .lf-device-inner {
    --lf-scale: 0.908;
}

.lf-theater.is-switching .lf-device-inner {
    --lf-scale: 0.887;
}

/* Mobile device preview — centered, full section height */
.lf-col--mockup:has(.lf-device--mobile) {
    align-items: stretch;
    justify-content: center;
}

.lf-mockup-scene:has(.lf-device--mobile),
.lf-mockup-well:has(.lf-device--mobile),
.lf-device--mobile {
    align-items: center;
    justify-content: center;
}

.lf-device--mobile .lf-device-inner {
    --lf-scale: 1;
    transform-origin: center center;
}

.lf-mockup-scene:has(.lf-device--mobile):hover .lf-device-inner {
    --lf-scale: 1.008;
}

.lf-theater.is-switching .lf-device--mobile .lf-device-inner {
    --lf-scale: .985;
}

.lf-device-screen {
    position: absolute;
    top: var(--lf-screen-top);
    right: var(--lf-screen-right);
    bottom: var(--lf-screen-bottom);
    left: var(--lf-screen-left);
    z-index: 1;
    overflow: hidden;
    border-radius: var(--lf-screen-radius, 4px);
    background: #0a0a0a;
    transition: top .5s var(--lf-ease), right .5s var(--lf-ease),
        bottom .5s var(--lf-ease), left .5s var(--lf-ease),
        border-radius .5s var(--lf-ease);
}

.lf-device-frame {
    position: absolute;
    inset: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    object-fit: fill;
    pointer-events: none;
    filter: drop-shadow(0 24px 48px rgba(0, 0, 0, .14)) drop-shadow(0 8px 20px rgba(0, 0, 0, .07));
    transition: opacity .4s ease;
}

.lf-device.is-switching .lf-device-frame {
    opacity: .9;
}

.lf-screens {
    display: flex;
    height: 100%;
    transition: transform .6s var(--lf-ease);
}

.lf-screen {
    flex: 0 0 100%;
    height: 100%;
    margin: 0;
}

.lf-screen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    display: block;
}

/* entrance */
.lf-reveal {
    opacity: 0;
    transform: translateY(16px);
}

.lf-reveal.is-visible {
    animation: lfIn .75s var(--lf-ease) forwards;
}

.lf-reveal[data-delay="1"].is-visible { animation-delay: .08s; }
.lf-reveal[data-delay="2"].is-visible { animation-delay: .16s; }
.lf-reveal[data-delay="3"].is-visible { animation-delay: .24s; }

.lf-col--mockup.lf-reveal.is-visible {
    animation: lfMockIn .9s var(--lf-ease) .12s forwards;
}

@keyframes lfIn {
    to { opacity: 1; transform: translateY(0); }
}

@keyframes lfMockIn {
    from { opacity: 0; transform: translateX(20px) scale(.97); }
    to { opacity: 1; transform: translateX(0) scale(1); }
}

/* responsive */
@media (max-width: 1024px) {
    .luxury-showcase {
        --lf-title-size: clamp(3rem, 6.8vw, 4.8rem);
        --lf-case-title: clamp(1.5rem, 2.2vw, 2rem);
        --lf-case-meta: clamp(0.88rem, 0.94vw, 0.96rem);
        --lf-case-desc: clamp(0.86rem, 0.9vw, 0.94rem);
    }

    .lf-master-grid {
        grid-template-columns: minmax(0, 42fr) minmax(0, 58fr);
        gap: clamp(32px, 4vw, 48px);
    }
}

@media (max-width: 900px) {
    .luxury-showcase {
        height: auto;
        min-height: calc(100svh - var(--header-height));
        max-height: none;
        overflow: visible;
        padding: clamp(40px, 7vh, 56px) clamp(16px, 4vw, 24px);
    }

    .lf-theater {
        height: auto;
        padding: clamp(40px, 6vh, 56px) clamp(24px, 4vw, 36px);
    }

    .lf-shell {
        height: auto;
    }

    .lf-master-grid {
        display: flex;
        flex-direction: column;
        gap: clamp(28px, 4vh, 36px);
    }

    .lf-col--left {
        display: contents;
    }

    .lf-header { order: 1; }
    .lf-device-row { order: 2; margin-bottom: 0; }
    .lf-col--mockup {
        order: 3;
        height: clamp(260px, 50vw, 400px);
    }

    .lf-col--left .lf-col--info { order: 4; max-width: 100%; }
    .lf-controls-bar { order: 5; max-width: 100%; }
}

@media (max-width: 768px) {
    .luxury-showcase {
        --lf-title-size: clamp(2.1rem, 9.8vw, 3.2rem);
        --lf-case-title: clamp(1.4rem, 5vw, 1.75rem);
        --lf-case-meta: clamp(0.86rem, 3.2vw, 0.94rem);
        --lf-case-desc: clamp(0.84rem, 3vw, 0.92rem);
        --lf-tab-size: clamp(0.72rem, 3.2vw, 0.8rem);
        --lf-tab-icon: 18px;
        --lf-gap: clamp(20px, 3.5vh, 28px);
    }

    .lf-theater {
        padding: clamp(36px, 6vw, 48px) clamp(24px, 4vw, 32px);
        border-radius: 20px;
    }

    .lf-heading {
        letter-spacing: -1.8px;
        max-width: 14ch;
    }

    .lf-device-switch {
        width: 100%;
    }

    .lf-device-btn {
        min-height: 44px;
        padding: 0 clamp(6px, 1.5vw, 12px);
    }

    .lf-col--mockup {
        height: clamp(280px, 52vw, 420px);
    }
}

@media (max-width: 480px) {
    .luxury-showcase {
        --lf-title-size: clamp(1.85rem, 10vw, 2.5rem);
        --lf-case-title: clamp(1.3rem, 6vw, 1.6rem);
    }

    .lf-device-btn-label { display: none; }
    .lf-device-btn {
        flex: 1 1 0;
        min-width: 0;
        min-height: 48px;
        padding: 0 10px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .lf-reveal,
    .lf-reveal.is-visible,
    .lf-col--mockup.lf-reveal.is-visible {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
    }

    .lf-device-inner,
    .lf-screens,
    .lf-project-category,
    .lf-project-title,
    .lf-project-meta,
    .lf-project-desc,
    .lf-device-btn,
    .lf-nav,
    .lf-cta,
    .lf-cta::after,
    .lf-cta svg {
        transition: none !important;
    }
}

/* projects end */

/* clients — dual carousel + editorial copy */

.icb-clients {
    --cl-ease: cubic-bezier(.22, 1, .36, 1);
    --cl-marquee-dur: 36s;
    --cl-glow-x: 50%;
    --cl-glow-y: 50%;
    position: relative;
    width: 100%;
    padding: clamp(92px, 9vh, 132px) clamp(20px, 3.5vw, 48px);
    overflow: hidden;
    scroll-margin-top: var(--header-height);
    background: #f7f7f7;
}

.icb-clients-bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 45% at var(--cl-glow-x) var(--cl-glow-y), rgba(255, 106, 0, .06), transparent 55%),
        linear-gradient(rgba(3, 3, 3, .022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(3, 3, 3, .022) 1px, transparent 1px);
    background-size: auto, 56px 56px, 56px 56px;
    pointer-events: none;
}

.icb-clients-glow {
    position: absolute;
    width: clamp(240px, 28vw, 360px);
    height: clamp(240px, 28vw, 360px);
    left: var(--cl-glow-x);
    top: var(--cl-glow-y);
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 106, 0, .1), transparent 68%);
    filter: blur(36px);
    opacity: 0;
    pointer-events: none;
    transition: opacity .5s ease;
    z-index: 0;
}

.icb-clients.is-active .icb-clients-glow {
    opacity: 1;
}

.icb-clients-wrap {
    position: relative;
    z-index: 1;
    width: min(100%, 1680px);
    margin: 0 auto;
}

.icb-clients-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
    gap: clamp(20px, 3vw, 40px);
    align-items: center;
}

/* ── carousels (left) ── */
.icb-clients-carousels {
    position: relative;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: clamp(14px, 2vh, 20px);
    overflow: hidden;
}

.icb-clients-fade--right {
    position: absolute;
    top: -4%;
    right: 0;
    width: clamp(140px, 22%, 320px);
    height: 108%;
    background: linear-gradient(to right, transparent 0%, rgba(247, 247, 247, .55) 35%, #f7f7f7 78%);
    z-index: 3;
    pointer-events: none;
}

.icb-clients-marquee {
    position: relative;
    overflow: hidden;
    width: 100%;
}

.icb-clients-track {
    display: flex;
    width: max-content;
}

.icb-clients-group {
    display: flex;
    align-items: stretch;
    flex-shrink: 0;
    padding-right: clamp(12px, 1.5vw, 18px);
    will-change: transform;
    backface-visibility: hidden;
}

.icb-clients-group > * {
    margin-right: clamp(12px, 1.5vw, 18px);
}

.icb-cl-scroll-left {
    animation: icbClMarqueeLeft var(--cl-marquee-dur) linear infinite;
}

.icb-cl-scroll-right {
    animation: icbClMarqueeRight var(--cl-marquee-dur) linear infinite;
}

.icb-clients-marquee:hover .icb-clients-group {
    animation-play-state: paused;
}

@keyframes icbClMarqueeLeft {
    0% { transform: translate3d(0, 0, 0); }
    100% { transform: translate3d(-100%, 0, 0); }
}

@keyframes icbClMarqueeRight {
    0% { transform: translate3d(-100%, 0, 0); }
    100% { transform: translate3d(0, 0, 0); }
}

.icb-cl-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    min-width: clamp(148px, 14vw, 196px);
    min-height: clamp(72px, 8vw, 96px);
    padding: clamp(16px, 2vw, 22px) clamp(22px, 2.4vw, 30px);
    border-radius: clamp(12px, 1.1vw, 16px);
    border: 1px solid rgba(3, 3, 3, .07);
    background: rgba(255, 255, 255, .88);
    backdrop-filter: blur(10px);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, .95) inset,
        0 6px 22px rgba(0, 0, 0, .04);
    transform-style: preserve-3d;
    --tilt-x: 0deg;
    --tilt-y: 0deg;
    --lift: 0px;
    transform: rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateZ(var(--lift));
    transition: transform .5s var(--cl-ease), border-color .35s ease, box-shadow .4s var(--cl-ease), color .35s ease;
}

.icb-cl-logo span {
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.95rem, 1.1vw, 1.15rem);
    letter-spacing: -.02em;
    line-height: 1.1;
    white-space: nowrap;
    transition: color .35s ease;
}

.icb-cl-logo:hover,
.icb-cl-logo.is-hovered {
    --lift: 8px;
    border-color: rgba(255, 106, 0, .28);
    box-shadow:
        0 1px 0 rgba(255, 255, 255, 1) inset,
        0 14px 36px rgba(255, 106, 0, .12),
        0 6px 18px rgba(0, 0, 0, .06);
}

.icb-cl-logo:hover span,
.icb-cl-logo.is-hovered span {
    color: var(--primary-orange);
}

/* ── copy (right) ── */
.icb-clients-copy {
    position: relative;
    z-index: 4;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: clamp(18px, 2.4vh, 28px);
    max-width: min(100%, 560px);
    margin-left: auto;
    padding: clamp(8px, 1.5vw, 16px) 0;
    text-align: right;
}

.icb-clients-headline {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: clamp(12px, 1.6vh, 18px);
    width: 100%;
}

.icb-clients-eyebrow {
    margin: 0;
    white-space: nowrap;
    font-size: clamp(0.62rem, 0.72vw, 0.76rem);
    line-height: 1.2;
    letter-spacing: 0.08em;
}

.icb-clients-title {
    margin: 0;
    white-space: nowrap;
    color: var(--primary-black, #030303);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 68px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -1.4px;
}

.icb-clients-title em {
    color: var(--primary-orange);
    font-style: normal;
}

.icb-clients-lead {
    margin: 0;
    color: rgba(3, 3, 3, .72);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: 18px;
    line-height: 1.55;
    max-width: 60ch;
    text-align: right;
}

/* entrance */
.icb-cl-reveal {
    opacity: 0;
    transform: translateY(24px);
    filter: blur(6px);
}

.icb-cl-reveal.is-visible {
    animation: icbClIn .85s var(--cl-ease) forwards;
}

.icb-cl-reveal[data-delay="1"].is-visible { animation-delay: .12s; }

@keyframes icbClIn {
    to { opacity: 1; transform: translateY(0); filter: blur(0); }
}

/* responsive */
@media (max-width: 1024px) {
    .icb-clients-layout {
        grid-template-columns: 1fr;
        gap: clamp(36px, 5vh, 48px);
    }

    .icb-clients-copy {
        order: -1;
        max-width: 100%;
        align-items: flex-end;
    }

    .icb-clients-headline {
        align-items: flex-end;
    }

    .icb-clients-eyebrow,
    .icb-clients-title {
        white-space: normal;
    }

    .icb-clients-fade--right {
        width: clamp(80px, 14%, 160px);
        background: linear-gradient(to right, transparent 0%, rgba(247, 247, 247, .7) 50%, #f7f7f7 100%);
    }

    .icb-clients-title {
        font-size: clamp(2.2rem, 6vw, 3.2rem);
    }
}

@media (max-width: 640px) {
    .icb-clients {
        padding: clamp(76px, 8vh, 92px) clamp(16px, 4vw, 20px);
    }

    .icb-cl-logo {
        min-width: 132px;
        min-height: 68px;
        padding: 14px 20px;
    }

    .icb-clients-headline {
        align-items: flex-end;
    }

    .icb-clients-eyebrow,
    .icb-clients-title {
        white-space: normal;
    }

    .icb-clients-lead br {
        display: none;
    }

    .icb-clients-lead {
        max-width: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .icb-cl-reveal,
    .icb-cl-reveal.is-visible {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .icb-cl-scroll-left,
    .icb-cl-scroll-right {
        animation: none !important;
    }

    .icb-cl-logo {
        transition: none !important;
    }
}

/* clients end */

/* about us — dark cinematic + left flare + mascot */

.icb-about {
    --ab-ease: cubic-bezier(.22, 1, .36, 1);
    --ab-bg: #030303;
    --ab-text: #f5f5f5;
    --ab-muted: rgba(245, 245, 245, .68);
    --ab-faint: rgba(245, 245, 245, .48);
    --ab-line: rgba(255, 255, 255, .1);
    position: relative;
    width: 100%;
    height: 100svh;
    min-height: 640px;
    max-height: 960px;
    display: grid;
    place-items: center start;
    padding:
        calc(var(--header-height) + clamp(32px, 5vh, 56px))
        clamp(32px, 5vw, 72px)
        clamp(32px, 5vh, 56px);
    overflow: hidden;
    scroll-margin-top: var(--header-height);
    background: var(--ab-bg);
    box-sizing: border-box;
    color: var(--ab-text);
}

.icb-about-bg {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(118deg, rgba(255, 106, 0, .16) 0%, rgba(255, 106, 0, .06) 22%, transparent 48%),
        linear-gradient(rgba(255, 255, 255, .022) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, .022) 1px, transparent 1px);
    background-size: 220% 100%, 56px 56px, 56px 56px;
    background-position: 0% 50%, 0 0, 0 0;
    pointer-events: none;
    z-index: 0;
    animation: icbAbGradientRun 16s linear infinite;
}

@keyframes icbAbGradientRun {
    0% { background-position: 0% 50%, 0 0, 0 0; }
    100% { background-position: 100% 50%, 0 0, 0 0; }
}

.icb-about-flare {
    position: absolute;
    inset: -20% auto -20% -15%;
    width: min(62vw, 720px);
    background:
        radial-gradient(ellipse 70% 55% at 28% 42%, rgba(255, 106, 0, .32), transparent 62%),
        radial-gradient(ellipse 50% 40% at 12% 78%, rgba(255, 138, 31, .18), transparent 58%),
        radial-gradient(ellipse 40% 35% at 35% 18%, rgba(255, 106, 0, .12), transparent 55%);
    filter: blur(2px);
    pointer-events: none;
    z-index: 0;
    animation: icbAbFlare 14s var(--ab-ease) infinite alternate;
}

.icb-about-vignette {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, transparent 55%, rgba(0, 0, 0, .35) 100%),
        linear-gradient(180deg, rgba(0, 0, 0, .2) 0%, transparent 18%, transparent 82%, rgba(0, 0, 0, .25) 100%);
    pointer-events: none;
    z-index: 1;
}

@keyframes icbAbFlare {
    0% {
        opacity: .72;
        transform: translateX(-3%) scale(1);
    }
    100% {
        opacity: 1;
        transform: translateX(4%) scale(1.06);
    }
}

.icb-about-wrap {
    position: relative;
    z-index: 3;
    width: min(100%, 1680px);
    margin: 0 auto;
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    justify-self: start;
}

.icb-about-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(24px, 3.2vh, 40px);
    width: min(100%, 720px);
    max-width: 52vw;
}

.icb-about-eyebrow {
    margin: 0 0 clamp(14px, 1.8vh, 20px);
    color: var(--primary-orange);
}

.icb-about-title {
    margin: 0;
    color: var(--ab-text);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(3rem, 5.8vw, 5.25rem);
    font-weight: 400;
    line-height: 1.02;
    letter-spacing: 0px;
}

.icb-about-title-line {
    display: block;
    white-space: nowrap;
}

.icb-ab-word {
    display: inline-block;
    opacity: 0;
    transform: translateY(1.05em);
    filter: blur(8px);
    transition: opacity .75s var(--ab-ease), transform .75s var(--ab-ease), filter .75s var(--ab-ease);
}

.icb-about-title.is-visible .icb-ab-word {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

.icb-about-copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(20px, 2.6vh, 30px);
    max-width: 610px;
}

.icb-about-lead {
    margin: 0;
    max-width: 610px;
    color: rgba(245, 245, 245, .82);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(0.98rem, 1vw, 1.08rem);
    line-height: 1.68;
}

.icb-about-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--ab-text);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.64rem, 0.72vw, 0.74rem);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    text-decoration: none;
    position: relative;
    padding-bottom: 5px;
    transition: color .35s var(--ab-ease), gap .35s var(--ab-ease);
}

.icb-about-cta::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: rgba(255, 255, 255, .32);
    transition: background .35s var(--ab-ease);
}

.icb-about-cta svg {
    flex-shrink: 0;
    transition: transform .4s var(--ab-ease);
}

.icb-about-cta:hover,
.icb-about-cta:focus-visible {
    color: var(--primary-orange);
    gap: 12px;
}

.icb-about-cta:hover::after,
.icb-about-cta:focus-visible::after {
    background: var(--primary-orange);
}

.icb-about-cta:hover svg,
.icb-about-cta:focus-visible svg {
    transform: translateX(3px);
}

.icb-about-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, max-content));
    gap: clamp(24px, 4vw, 64px);
    padding-top: clamp(28px, 3.5vh, 44px);
    margin-top: clamp(4px, 1vh, 12px);
    border-top: 1px solid var(--ab-line);
    width: 100%;
}

.icb-ab-stat {
    display: flex;
    flex-direction: column;
    gap: clamp(6px, 0.8vh, 10px);
}

.icb-ab-stat:not(:first-child) {
    padding-left: clamp(24px, 3.5vw, 56px);
    border-left: 1px solid var(--ab-line);
}

.icb-ab-stat-num {
    color: var(--ab-text);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2.75rem, 4.8vw, 4.25rem);
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.04em;
    font-variant-numeric: tabular-nums;
}

.icb-ab-stat-label {
    color: var(--ab-faint);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(0.88rem, 1vw, 1.05rem);
    line-height: 1.45;
    white-space: nowrap;
}

.icb-about-mascot {
    position: absolute;
    top: 10%;
    right: clamp(-16px, -1.5vw, 0px);
    bottom: 0;
    z-index: 2;
    width: min(62vw, 980px);
    margin: 0;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    pointer-events: none;
}

.icb-about-mascot::after {
    content: "";
    position: absolute;
    inset: 0 0 0 12%;
    background: linear-gradient(to right, var(--ab-bg) 0%, transparent 38%);
    z-index: 2;
    pointer-events: none;
}

.icb-about-mascot img {
    --ab-mascot-x: 0px;
    --ab-mascot-y: 0px;
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: right bottom;
    transform: translate3d(var(--ab-mascot-x), var(--ab-mascot-y), 0);
    transition: transform .22s ease-out;
}

.icb-ab-reveal {
    opacity: 0;
    transform: translateY(22px);
    filter: blur(5px);
}

.icb-ab-reveal.is-visible {
    animation: icbAbIn .85s var(--ab-ease) forwards;
}

.icb-ab-reveal[data-delay="1"].is-visible { animation-delay: .08s; }
.icb-ab-reveal[data-delay="2"].is-visible { animation-delay: .18s; }
.icb-ab-reveal[data-delay="3"].is-visible { animation-delay: .28s; }
.icb-ab-reveal[data-delay="4"].is-visible { animation-delay: .38s; }

@keyframes icbAbIn {
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@media (max-width: 1100px) {
    .icb-about-content {
        max-width: min(100%, 580px);
        width: min(100%, 48vw);
    }

    .icb-about-title {
        font-size: clamp(2.6rem, 5.2vw, 4.25rem);
    }

    .icb-about-mascot {
        width: min(58vw, 820px);
    }
}

@media (max-width: 900px) {
    .icb-about {
        height: 100svh;
        min-height: 580px;
        padding:
            calc(var(--header-height) + clamp(24px, 4vh, 40px))
            clamp(24px, 4vw, 40px)
            clamp(24px, 4vh, 40px);
    }

    .icb-about-content {
        width: min(100%, 480px);
        max-width: calc(100% - min(28vw, 160px));
    }

    .icb-about-title {
        font-size: clamp(2.2rem, 7vw, 3.2rem);
    }

    .icb-about-title-line {
        white-space: normal;
    }

    .icb-about-stats {
        gap: clamp(16px, 3vw, 28px);
        padding-top: clamp(22px, 3vh, 32px);
    }

    .icb-ab-stat:not(:first-child) {
        padding-left: clamp(16px, 3vw, 28px);
    }

    .icb-ab-stat-num {
        font-size: clamp(2rem, 6vw, 2.75rem);
    }

    .icb-ab-stat-label {
        white-space: normal;
        font-size: clamp(0.8rem, 2.2vw, 0.92rem);
    }

    .icb-about-mascot {
        top: 12%;
        width: min(52vw, 480px);
    }

    .icb-about-flare {
        width: min(75vw, 520px);
    }
}

@media (max-width: 640px) {
    .icb-about {
        padding:
            calc(var(--header-height) + clamp(20px, 3vh, 32px))
            clamp(20px, 5vw, 28px)
            clamp(20px, 3vh, 32px);
    }

    .icb-about-content {
        width: 100%;
        max-width: 100%;
    }

    .icb-about-mascot {
        top: 14%;
        width: min(82vw, 360px);
        right: -10px;
        opacity: 0.94;
    }

    .icb-about-mascot::after {
        inset: 0 0 0 6%;
        background: linear-gradient(to right, var(--ab-bg) 0%, transparent 24%);
    }

    .icb-about-stats {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .icb-ab-stat:not(:first-child) {
        padding-left: 0;
        border-left: none;
        padding-top: clamp(14px, 2vh, 18px);
        margin-top: clamp(14px, 2vh, 18px);
        border-top: 1px solid var(--ab-line);
    }

    .icb-about-title {
        font-size: clamp(2rem, 9vw, 2.65rem);
    }

    .icb-ab-stat-num {
        font-size: clamp(2rem, 9vw, 2.5rem);
    }
}

@media (prefers-reduced-motion: reduce) {
    .icb-about-bg,
    .icb-about-flare {
        animation: none !important;
    }

    .icb-ab-reveal,
    .icb-ab-reveal.is-visible {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .icb-ab-word {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }

    .icb-about-mascot img {
        transition: none !important;
    }

    .icb-about-cta,
    .icb-about-cta::after,
    .icb-about-cta svg {
        transition: none !important;
    }
}

/* about end */

/* industries we serve — editorial sketch carousel */

.icb-industries {
    --ind-ease: cubic-bezier(.22, 1, .36, 1);
    position: relative;
    width: 100%;
    padding:
    clamp(112px, calc(16vh + 40px), 152px)
    clamp(40px, 6vw, 88px)
    clamp(112px, calc(10vh + 40px), 152px);
    overflow: hidden;
    scroll-margin-top: var(--header-height);
    background: #ffffff;
}

.icb-ind-bg {
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 70% 50% at 50% -10%, rgba(255, 106, 0, .07), transparent 55%),
        linear-gradient(rgba(3, 3, 3, .028) 1px, transparent 1px),
        linear-gradient(90deg, rgba(3, 3, 3, .028) 1px, transparent 1px);
    background-size: auto, 56px 56px, 56px 56px;
    pointer-events: none;
}

.icb-ind-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(60px);
    pointer-events: none;
    opacity: .55;
}

.icb-ind-orb--left {
    width: min(36vw, 420px);
    height: min(36vw, 420px);
    left: -8%;
    top: 18%;
    background: rgba(255, 106, 0, .12);
    animation: icbIndOrb 18s var(--ind-ease) infinite alternate;
}

.icb-ind-orb--right {
    width: min(28vw, 320px);
    height: min(28vw, 320px);
    right: -6%;
    bottom: 8%;
    background: rgba(255, 106, 0, .06);
    animation: icbIndOrb 22s var(--ind-ease) infinite alternate-reverse;
}

@keyframes icbIndOrb {
    to { transform: translate(4%, -6%) scale(1.08); }
}

.icb-ind-wrap {
    position: relative;
    z-index: 1;
    width: min(100%, 1680px);
    max-width: min(100%, 1120px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: clamp(24px, 3vh, 36px);
    overflow: visible;
}

.icb-ind-head {
    position: relative;
    max-width: min(100%, 640px);
    margin-bottom: 20px;
}

.icb-ind-head::after {
    content: "";
    position: absolute;
    left: 18%;
    top: 28%;
    width: min(70%, 480px);
    height: min(90%, 220px);
    transform: translate(0, 0);
    background:
        radial-gradient(ellipse 80% 70% at 20% 25%, rgba(72, 34, 14, .16), transparent 68%),
        radial-gradient(ellipse 60% 55% at 35% 40%, rgba(42, 20, 10, .12), transparent 62%),
        radial-gradient(ellipse 90% 80% at 15% 30%, rgba(55, 26, 12, .07), transparent 72%);
    filter: blur(36px);
    opacity: .38;
    z-index: -1;
    pointer-events: none;
    animation: icbIndTitleSmog 7s ease-in-out infinite alternate;
}

@keyframes icbIndTitleSmog {
    0% {
        opacity: .28;
        transform: translate(0, 0) scale(.94);
        filter: blur(32px);
    }
    100% {
        opacity: .42;
        transform: translate(3%, 2%) scale(1.04);
        filter: blur(40px);
    }
}

.icb-ind-kicker {
    display: block;
    width: 6px;
    height: 6px;
    margin: 0 auto clamp(10px, 1.4vh, 14px);
    border-radius: 50%;
    background: var(--primary-orange);
    box-shadow: 0 0 0 4px rgba(255, 106, 0, .1);
}

.icb-ind-title {
    --ind-title-grad: linear-gradient(
        148deg,
        #4a2818 0%,
        #3d2014 7%,
        #322018 14%,
        #281a14 22%,
        rgba(38, 22, 16, .9) 32%,
        rgba(24, 16, 14, .95) 42%,
        rgba(14, 12, 12, .98) 52%,
        #080808 62%,
        #030303 72%,
        #030303 100%
    );
    --title-fill-dur: 6.5s;
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 48px;
    font-weight: 400;
    line-height: 1.14;
    letter-spacing: -0.03em;
}

.icb-ind-title-line {
    display: block;
    background-image: var(--ind-title-grad);
    background-size: 320% 320%;
    background-repeat: no-repeat;
    background-position: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: icbIndTitleFill var(--title-fill-dur, 6.5s) ease-in-out infinite;
}

.icb-ind-title-line.is-split {
    background: none;
    animation: none;
    -webkit-background-clip: border-box;
    background-clip: border-box;
    color: inherit;
    -webkit-text-fill-color: currentColor;
}

.icb-ind-title-line:nth-child(2) {
    animation-delay: calc(var(--title-fill-dur, 6.5s) * -0.08);
}

.icb-ind-title-line.is-split:nth-child(2) .icb-ind-word {
    animation-delay: calc(var(--title-fill-dur, 6.5s) * -0.08);
}

.icb-ind-title-line--accent,
.icb-ind-title-line:not(.icb-ind-title-line--accent) {
    color: transparent;
    -webkit-text-fill-color: transparent;
}

@keyframes icbIndTitleFill {
    0% {
        background-position: 100% 100%;
    }
    42% {
        background-position: 0% 0%;
    }
    58% {
        background-position: 0% 0%;
    }
    100% {
        background-position: 100% 100%;
    }
}

.icb-ind-word {
    display: inline-block;
    background-image: var(--ind-title-grad);
    background-size: 320% 320%;
    background-repeat: no-repeat;
    background-attachment: fixed;
    background-position: 100% 100%;
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    animation: icbIndTitleFill var(--title-fill-dur, 6.5s) ease-in-out infinite;
    opacity: 0;
    transform: translateY(1.15em);
    filter: blur(10px);
    transition: opacity .85s var(--ind-ease), transform .85s var(--ind-ease), filter .85s var(--ind-ease);
}

.icb-ind-title.is-visible .icb-ind-word,
.icb-industries.is-visible .icb-ind-word,
.icb-ind-head.is-visible .icb-ind-word {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

.icb-ind-stage {
    width: 100%;
    max-width: min(100%, 940px);
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: visible;
}

.icb-ind-viewport {
    position: relative;
    overflow-x: clip;
    overflow-y: visible;
    width: 100%;
    margin: 0 auto;
    padding: clamp(20px, 2.5vh, 28px) 0 clamp(8px, 1vh, 12px);
}

.icb-ind-fade {
    position: absolute;
    top: clamp(20px, 2.5vh, 28px);
    bottom: clamp(8px, 1vh, 12px);
    width: clamp(48px, 8vw, 120px);
    z-index: 2;
    pointer-events: none;
}

.icb-ind-fade--left {
    left: 0;
    background: linear-gradient(to right, #ffffff 12%, transparent);
}

.icb-ind-fade--right {
    right: 0;
    background: linear-gradient(to left, #ffffff 12%, transparent);
}

.icb-ind-track {
    --ind-gap: clamp(10px, 1.8vw, 22px);
    --ind-cols: 5;
    display: flex;
    gap: var(--ind-gap);
    will-change: transform;
    justify-content: flex-start;
    align-items: center;
}

.icb-ind-card {
    flex: 0 0 calc((100% - (var(--ind-cols) - 1) * var(--ind-gap)) / var(--ind-cols));
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(12px, 1.6vh, 16px);
    padding: clamp(4px, 0.6vh, 8px) clamp(4px, 0.6vw, 6px);
    background: transparent;
    border: none;
    cursor: default;
    overflow: visible;
    opacity: 0;
    transform: translateY(32px);
    filter: blur(6px);
    transition:
        opacity .75s var(--ind-ease),
        transform .75s var(--ind-ease),
        filter .75s var(--ind-ease);
}

.icb-ind-card.is-visible {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

.icb-ind-icon-wrap {
    position: relative;
    z-index: 1;
    width: clamp(80px, 7.5vw, 100px);
    height: clamp(80px, 7.5vw, 100px);
    display: flex;
    align-items: center;
    justify-content: center;
    --tilt-x: 0deg;
    --tilt-y: 0deg;
    transform: perspective(600px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
    transform-style: preserve-3d;
    transition: transform .55s var(--ind-ease);
}

.icb-ind-card.is-hovered .icb-ind-icon-wrap,
.icb-ind-card:focus-visible .icb-ind-icon-wrap {
    transform: perspective(600px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateY(-18px) scale(1.06);
}

.icb-ind-card.is-active .icb-ind-icon-ring {
    border-color: rgba(3, 3, 3, .2);
}

.icb-ind-icon-ring {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 1.5px dashed rgba(3, 3, 3, .14);
    transition:
        border-color .45s var(--ind-ease),
        transform .6s var(--ind-ease),
        box-shadow .45s var(--ind-ease);
}

.icb-ind-card.is-hovered .icb-ind-icon-ring,
.icb-ind-card:focus-visible .icb-ind-icon-ring {
    border-color: rgba(255, 106, 0, .55);
    transform: rotate(12deg) scale(1.08);
    box-shadow: 0 12px 28px rgba(255, 106, 0, .14), 0 0 0 10px rgba(255, 106, 0, .06);
}

.icb-ind-icon {
    position: relative;
    z-index: 1;
    width: 72%;
    height: 72%;
    color: var(--primary-black);
    animation: icbIndFloat 5s var(--ind-ease) infinite;
}

.icb-ind-card:nth-child(2n) .icb-ind-icon { animation-delay: -.8s; }
.icb-ind-card:nth-child(3n) .icb-ind-icon { animation-delay: -1.6s; }

@keyframes icbIndFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-3px); }
}

.icb-ind-icon svg {
    width: 100%;
    height: 100%;
    overflow: visible;
}

.icb-ind-draw {
    stroke: currentColor;
    stroke-width: 2.2;
    stroke-linecap: round;
    stroke-linejoin: round;
    fill: none;
    vector-effect: non-scaling-stroke;
}

.icb-ind-card.is-visible .icb-ind-draw {
    stroke-dasharray: 220;
    stroke-dashoffset: 220;
    animation: icbIndDraw 1.1s var(--ind-ease) forwards;
}

.icb-ind-card.is-hovered .icb-ind-icon,
.icb-ind-card:focus-visible .icb-ind-icon {
    color: var(--primary-orange);
    animation-play-state: paused;
}

@keyframes icbIndDraw {
    to { stroke-dashoffset: 0; }
}

.icb-ind-label {
    color: var(--primary-black);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.78rem, 0.84vw, 0.88rem);
    letter-spacing: 0.015em;
    line-height: 1.3;
    transition: color .4s var(--ind-ease), transform .4s var(--ind-ease);
}

.icb-ind-card.is-hovered .icb-ind-label,
.icb-ind-card:focus-visible .icb-ind-label {
    color: var(--primary-orange);
    transform: translateY(-4px);
}

.icb-ind-card:focus-visible {
    outline: none;
}

.icb-ind-card:focus-visible .icb-ind-icon-wrap {
    outline: 2px solid rgba(255, 106, 0, .4);
    outline-offset: 6px;
    border-radius: 50%;
}

.icb-ind-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(14px, 2vw, 22px);
    width: min(100%, 400px);
    margin-top: clamp(8px, 1vh, 14px);
}

.icb-ind-nav {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid rgba(3, 3, 3, .28);
    border-radius: 50%;
    background: rgba(255, 255, 255, .92);
    color: var(--primary-black);
    cursor: pointer;
    box-shadow:
        0 4px 16px rgba(3, 3, 3, .12),
        inset 0 1px 0 rgba(255, 255, 255, .95);
    transition:
        border-color .4s var(--ind-ease),
        color .4s var(--ind-ease),
        transform .4s var(--ind-ease),
        background .4s var(--ind-ease),
        box-shadow .4s var(--ind-ease);
}

.icb-ind-nav svg {
    width: 18px;
    height: 18px;
}

.icb-ind-nav:hover:not(:disabled),
.icb-ind-nav:focus-visible:not(:disabled) {
    border-color: var(--primary-orange);
    background: linear-gradient(145deg, #030303 0%, #1a0a00 55%, #ff6a00 100%);
    color: #fff;
    transform: scale(1.1);
    box-shadow:
        0 8px 24px rgba(255, 106, 0, .28),
        0 0 0 3px rgba(255, 106, 0, .12);
}

.icb-ind-nav:disabled {
    opacity: 0.28;
    cursor: not-allowed;
}

.icb-ind-progress {
    flex: 1;
    height: 3px;
    background: rgba(3, 3, 3, .16);
    border-radius: 999px;
    overflow: hidden;
}

.icb-ind-progress-fill {
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, #030303 0%, #ff6a00 100%);
    border-radius: inherit;
    transform: scaleX(0.5);
    transform-origin: left center;
    transition: transform .85s var(--ind-ease);
}

.icb-ind-cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 0 clamp(32px, 3.8vw, 44px);
    border-radius: 999px;
    background: linear-gradient(128deg, #030303 0%, #141414 38%, #3d1800 62%, #ff6a00 100%);
    background-size: 200% 200%;
    background-position: 0% 50%;
    border: 1px solid rgba(255, 106, 0, .42);
    color: #fff;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.66rem, 0.74vw, 0.76rem);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-decoration: none;
    overflow: hidden;
    isolation: isolate;
    box-shadow:
        0 14px 36px rgba(3, 3, 3, .28),
        0 6px 20px rgba(255, 106, 0, .22),
        inset 0 1px 0 rgba(255, 255, 255, .14),
        inset 0 -1px 0 rgba(0, 0, 0, .35);
    transition:
        transform .55s var(--ind-ease),
        box-shadow .55s var(--ind-ease),
        border-color .55s var(--ind-ease),
        background-position .65s var(--ind-ease),
        color .45s var(--ind-ease);
}

.icb-ind-cta-text {
    position: relative;
    z-index: 2;
    transition: letter-spacing .55s var(--ind-ease), color .45s var(--ind-ease);
}

.icb-ind-cta-shine {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(
        105deg,
        transparent 30%,
        rgba(255, 255, 255, .22) 46%,
        rgba(255, 106, 0, .35) 54%,
        transparent 70%
    );
    transform: translateX(-130%);
    transition: transform .75s var(--ind-ease);
}

.icb-ind-cta-glow {
    position: absolute;
    inset: -4px;
    z-index: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(255, 106, 0, .55), rgba(3, 3, 3, .4), rgba(255, 106, 0, .45));
    opacity: 0;
    filter: blur(16px);
    transition: opacity .55s var(--ind-ease), transform .55s var(--ind-ease);
}

.icb-ind-cta::before {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    padding: 1px;
    background: linear-gradient(135deg, rgba(255, 106, 0, .75), rgba(255, 255, 255, .25), rgba(3, 3, 3, .6));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: .65;
    transition: opacity .55s var(--ind-ease);
    pointer-events: none;
}

.icb-ind-cta:hover,
.icb-ind-cta:focus-visible {
    transform: translateY(-6px) scale(1.05);
    background-position: 100% 50%;
    border-color: rgba(255, 138, 31, .65);
    color: #fff;
    box-shadow:
        0 22px 48px rgba(3, 3, 3, .35),
        0 12px 32px rgba(255, 106, 0, .38),
        0 0 0 1px rgba(255, 106, 0, .25),
        inset 0 1px 0 rgba(255, 255, 255, .22);
    animation: icbIndCtaPulse 2.2s var(--ind-ease) infinite;
}

.icb-ind-cta:hover::before,
.icb-ind-cta:focus-visible::before {
    opacity: 1;
}

.icb-ind-cta:hover .icb-ind-cta-shine,
.icb-ind-cta:focus-visible .icb-ind-cta-shine {
    transform: translateX(130%);
}

.icb-ind-cta:hover .icb-ind-cta-glow,
.icb-ind-cta:focus-visible .icb-ind-cta-glow {
    opacity: 1;
    transform: scale(1.08);
}

.icb-ind-cta:hover .icb-ind-cta-text,
.icb-ind-cta:focus-visible .icb-ind-cta-text {
    letter-spacing: 0.18em;
}

@keyframes icbIndCtaPulse {
    0%, 100% {
        box-shadow:
            0 22px 48px rgba(3, 3, 3, .35),
            0 12px 32px rgba(255, 106, 0, .38),
            inset 0 1px 0 rgba(255, 255, 255, .22);
    }
    50% {
        box-shadow:
            0 26px 56px rgba(3, 3, 3, .4),
            0 16px 40px rgba(255, 106, 0, .48),
            0 0 32px rgba(255, 106, 0, .22),
            inset 0 1px 0 rgba(255, 255, 255, .28);
    }
}

.icb-ind-reveal {
    opacity: 0;
    transform: translateY(28px);
    filter: blur(6px);
}

.icb-ind-reveal.is-visible {
    animation: icbIndIn .9s var(--ind-ease) forwards;
}

.icb-ind-reveal[data-delay="1"].is-visible { animation-delay: .12s; }
.icb-ind-reveal[data-delay="2"].is-visible { animation-delay: .24s; }
.icb-ind-reveal[data-delay="3"].is-visible { animation-delay: .36s; }

@keyframes icbIndIn {
    to {
        opacity: 1;
        transform: translateY(0);
        filter: blur(0);
    }
}

@media (max-width: 900px) {
    .icb-industries {
        padding:
            clamp(96px, calc(8vh + 40px), 128px)
            clamp(28px, 5vw, 48px)
            clamp(96px, calc(8vh + 40px), 128px);
    }

    .icb-ind-title {
        font-size: clamp(1.55rem, 4.5vw, 2rem);
    }

    .icb-ind-stage {
        max-width: min(100%, 720px);
    }

    .icb-ind-track {
        --ind-cols: 3;
    }

    .icb-ind-icon-wrap {
        width: clamp(76px, 12vw, 92px);
        height: clamp(76px, 12vw, 92px);
    }
}

@media (max-width: 640px) {
    .icb-industries {
        padding:
            clamp(88px, calc(7vh + 40px), 112px)
            clamp(24px, 5vw, 32px)
            clamp(88px, calc(7vh + 40px), 112px);
    }

    .icb-ind-wrap {
        gap: clamp(20px, 2.8vh, 28px);
    }

    .icb-ind-title {
        font-size: clamp(1.4rem, 6.5vw, 1.75rem);
    }

    .icb-ind-stage {
        max-width: 100%;
    }

    .icb-ind-track {
        --ind-cols: 2;
    }

    .icb-ind-icon-wrap {
        width: 72px;
        height: 72px;
    }

    .icb-ind-controls {
        width: min(100%, 280px);
    }

    .icb-ind-fade {
        width: 28px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .icb-ind-orb,
    .icb-ind-orb--left,
    .icb-ind-orb--right {
        animation: none !important;
    }

    .icb-ind-icon {
        animation: none !important;
    }

    .icb-ind-card.is-visible .icb-ind-draw {
        animation: none !important;
        stroke-dashoffset: 0 !important;
    }

    .icb-ind-reveal,
    .icb-ind-reveal.is-visible {
        animation: none !important;
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .icb-ind-word {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
        animation: none !important;
        background-position: 12% 8% !important;
    }

    .icb-ind-title-line {
        animation: none !important;
        background-position: 12% 8% !important;
    }

    .icb-ind-head::after {
        animation: none !important;
        opacity: .32 !important;
    }

    .icb-ind-card {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
    }

    .icb-ind-track,
    .icb-ind-progress-fill,
    .icb-ind-nav,
    .icb-ind-cta,
    .icb-ind-cta::before,
    .icb-ind-cta-shine,
    .icb-ind-cta-glow,
    .icb-ind-cta-text,
    .icb-ind-icon-wrap,
    .icb-ind-icon-ring,
    .icb-ind-label {
        transition: none !important;
    }

    .icb-ind-cta:hover,
    .icb-ind-cta:focus-visible {
        animation: none !important;
    }
}

/* industries end */


 /* blogs — premium insights carousel */

.insight-premium-section {
    --ins-prem-ease: cubic-bezier(.22, 1, .36, 1);
    position: relative;
    padding: clamp(160px, 9vh, 108px) clamp(16px, 2.5vw, 32px);
    overflow: hidden;
    background:white;
    color: var(--primary-black);
    scroll-margin-top: var(--header-height);
}

.insight-premium-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 58% 62% at 50% 54%, rgba(255, 106, 0, .085) 0%, rgba(255, 120, 40, .038) 32%, transparent 68%),
        radial-gradient(ellipse 42% 48% at 50% 50%, rgba(255, 140, 60, .055) 0%, rgba(255, 106, 0, .018) 42%, transparent 72%),
        radial-gradient(ellipse 78% 52% at 50% 50%, rgba(255, 106, 0, .022) 0%, transparent 78%),
        linear-gradient(rgba(3, 3, 3, .026) 1px, transparent 1px),
        linear-gradient(90deg, rgba(3, 3, 3, .026) 1px, transparent 1px);
    background-size: auto, auto, auto, 56px 56px, 56px 56px;
    mask-image: radial-gradient(ellipse 92% 88% at 50% 52%, #000 42%, transparent 100%);
}

.insight-premium-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .38;
    background:
        repeating-linear-gradient(
            -14deg,
            rgba(255, 106, 0, 0) 0px,
            rgba(255, 106, 0, 0) 14px,
            rgba(255, 106, 0, .008) 14px,
            rgba(255, 106, 0, .008) 15px
        );
    mix-blend-mode: multiply;
    pointer-events: none;
    mask-image: radial-gradient(ellipse 88% 84% at 50% 52%, #000 38%, transparent 100%);
}

.insight-premium-wrap {
    position: relative;
    z-index: 2;
    width: min(100%, 1680px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: clamp(18px, 2.5vh, 28px);
}

.insight-premium-head {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 465px);
    gap: clamp(16px, 3vw, 36px);
    align-items: end;
    width: 100%; 
    padding-left:20px;
}

.insight-premium-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 12px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1.2px;
    line-height: 1.2;
    text-transform: uppercase;
    color:#ff6a00;
}

.insight-premium-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary-orange);
    box-shadow: 0 0 12px rgba(255, 106, 0, .55);
    flex-shrink: 0;
}

.insight-premium-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2rem, 3.6vw, 3.75rem);
    font-weight: 400;
    line-height: 1.06;
    letter-spacing: -1.2px;
    color: var(--primary-black);
}

.insight-premium-desc {
    margin: 0;
    max-width: 465px;
    justify-self: end;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.94rem, 1vw, 1.05rem);
    font-weight: 400;
    line-height: 1.4;
    letter-spacing: 0.2px;
    color: #000000;
}

.insight-premium-stage {
    position: relative;
    width: 100%;
}

.insight-premium-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
}

.insight-nav-btn {
    position: absolute;
    top: 50%;
    z-index: 40;
    width: clamp(46px, 4.2vw, 52px);
    height: clamp(46px, 4.2vw, 52px);
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(3, 3, 3, .06);
    border-radius: 50%;
    background: #fff;
    color: var(--primary-black);
    cursor: pointer;
    transform: translateY(-50%);
    box-shadow:
        0 1px 2px rgba(3, 3, 3, .04),
        0 6px 16px rgba(3, 3, 3, .07),
        0 14px 32px rgba(255, 106, 0, .11),
        0 28px 56px rgba(3, 3, 3, .05),
        inset 0 1px 0 rgba(255, 255, 255, 1),
        inset 0 -1px 0 rgba(3, 3, 3, .04);
    transition:
        transform .35s var(--ins-prem-ease),
        border-color .35s var(--ins-prem-ease),
        background .35s var(--ins-prem-ease),
        box-shadow .35s var(--ins-prem-ease),
        color .35s var(--ins-prem-ease);
}

.insight-nav-btn svg {
    width: 18px;
    height: 18px;
    filter: drop-shadow(0 1px 1px rgba(3, 3, 3, .12));
    transition: filter .35s var(--ins-prem-ease);
}

.insight-nav-btn--prev {
    left: clamp(0px, 0.5vw, 8px);
}

.insight-nav-btn--next {
    right: clamp(0px, 0.5vw, 8px);
}

.insight-nav-btn:hover,
.insight-nav-btn:focus-visible {
    border-color: rgba(255, 106, 0, .22);
    background: #fff;
    color: var(--primary-orange);
    transform: translateY(-50%) scale(1.06);
    box-shadow:
        0 2px 4px rgba(3, 3, 3, .05),
        0 10px 24px rgba(255, 106, 0, .16),
        0 20px 44px rgba(255, 106, 0, .1),
        0 0 0 4px rgba(255, 106, 0, .08),
        inset 0 1px 0 rgba(255, 255, 255, 1),
        inset 0 -1px 0 rgba(255, 106, 0, .06);
}

.insight-nav-btn:hover svg,
.insight-nav-btn:focus-visible svg {
    filter: drop-shadow(0 2px 4px rgba(255, 106, 0, .22));
}

.insights-viewport {
    perspective: 1600px;
    transform-style: preserve-3d;
    width: 100%;
}

.insights-track {
    position: relative;
    width: 100%;
    height: clamp(420px, 32vw, 520px);
    transform-style: preserve-3d;
}

.insight-slide {
    position: absolute;
    left: 50%;
    top: 50%;
    width: clamp(320px, 28vw, 400px);
    height: clamp(400px, 30vw, 480px);
    max-width: 82vw;
    transform-style: preserve-3d;
    will-change: transform, opacity;
    cursor: pointer;
}

.insight-glass-card {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: clamp(20px, 2vw, 28px);
    background: #0a0a0a;
    border: 1px solid rgba(255, 255, 255, .08);
    overflow: hidden;
    transform-style: preserve-3d;
    box-shadow: 0 24px 56px rgba(3, 3, 3, .18);
}

.parallax-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #0a0a0a;
    z-index: 1;
    transform: scale(1.05);
    will-change: transform;
}

.parallax-bg::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(3, 3, 3, .08) 0%, rgba(3, 3, 3, .2) 40%, rgba(3, 3, 3, .88) 100%);
    z-index: 2;
}

.insight-content-wrap {
    position: absolute;
    inset: 0;
    z-index: 10;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: clamp(22px, 2.5vw, 32px);
}

.parallax-content {
    display: flex;
    flex-direction: column;
}

.insight-card-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 11px;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    line-height: 1.2;
}

.insight-card-cat {
    color: var(--primary-orange);
}

.insight-card-sep {
    width: 1px;
    height: 10px;
    background: rgba(255, 255, 255, .28);
}

.insight-card-time {
    color: rgba(255, 255, 255, .72);
}

.insight-card-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(1.15rem, 1.5vw, 1.45rem);
    font-weight: 400;
    line-height: 1.22;
    letter-spacing: 0.4px;
    color: #fff;
    transition: color .35s var(--ins-prem-ease);
}

.insight-slide.is-focused .insight-card-title {
    color: #fff;
}

.insight-card-cta {
    display: inline-flex;
    align-items: center;
    align-self: flex-start;
    margin-top: clamp(14px, 1.8vh, 18px);
    padding: 0;
    border: none;
    background: none;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 12px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--primary-orange);
    text-decoration: none;
    opacity: .72;
    transform: translateY(0);
    transition:
        opacity .4s var(--ins-prem-ease),
        color .35s var(--ins-prem-ease);
}

.insight-slide.is-focused .insight-card-cta {
    opacity: 1;
}

.insight-card-cta:hover,
.insight-card-cta:focus-visible {
    color: #ffb366;
}

.insight-premium-section.is-sliding .insight-glass-card::before {
    opacity: 0 !important;
}

.insight-slide.is-focused .insight-glass-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 2px;
    background: linear-gradient(135deg, #ff6a00, #ffc47a, transparent, #ff6a00, #ff8a1f);
    background-size: 220% auto;
    animation: insightBorderRun 4s linear infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    pointer-events: none;
    z-index: 12;
    opacity: 1;
}

@keyframes insightBorderRun {
    0% { background-position: 0% 50%; }
    100% { background-position: 220% 50%; }
}

.matrix-dot {
    height: 8px;
    width: 8px;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: rgba(3, 3, 3, .14);
    cursor: pointer;
    transition:
        width .45s var(--ins-prem-ease),
        background .35s var(--ins-prem-ease),
        box-shadow .35s var(--ins-prem-ease);
}

.matrix-dot.active {
    width: 28px;
    background: var(--primary-orange);
    box-shadow: 0 0 16px rgba(255, 106, 0, .35);
}

@media (max-width: 1024px) {
    .insight-premium-head {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .insight-premium-desc {
        justify-self: start;
        max-width: 560px;
    }
}

@media (max-width: 768px) {
    .insight-premium-section {
        padding: clamp(56px, 8vh, 80px) clamp(14px, 4vw, 20px);
    }

    .insight-premium-title {
        font-size: clamp(1.75rem, 6.5vw, 2.35rem);
    }

    .insight-nav-btn {
        width: 42px;
        height: 42px;
    }
}

/* blogs end */

/* FAQ + Contact — merged light section */

@keyframes fcBorderRun {
    0% { background-position: 0% 50%; }
    100% { background-position: 220% 50%; }
}

.icb-faq-contact-section {
    --fc-ease: cubic-bezier(.22, 1, .36, 1);
    position: relative;
    padding: clamp(72px, 9vh, 112px) clamp(16px, 2.5vw, 32px) clamp(56px, 7vh, 80px);
    overflow: hidden;
    background: #fff;
    color: var(--primary-black);
    scroll-margin-top: var(--header-height);
}

.icb-faq-contact-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 62% 58% at 50% 42%, rgba(255, 106, 0, .09) 0%, rgba(255, 120, 40, .038) 34%, transparent 68%),
        radial-gradient(ellipse 48% 44% at 50% 50%, rgba(255, 140, 60, .05) 0%, transparent 72%),
        radial-gradient(ellipse 80% 52% at 50% 100%, rgba(255, 106, 0, .04) 0%, transparent 62%),
        linear-gradient(rgba(255, 106, 0, .018) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 106, 0, .018) 1px, transparent 1px);
    background-size: auto, auto, auto, 56px 56px, 56px 56px;
    mask-image: radial-gradient(ellipse 94% 90% at 50% 48%, #000 42%, transparent 100%);
}

.icb-faq-contact-bg::after {
    content: "";
    position: absolute;
    inset: 0;
    opacity: .35;
    background:
        repeating-linear-gradient(
            -14deg,
            rgba(255, 106, 0, 0) 0px,
            rgba(255, 106, 0, 0) 14px,
            rgba(255, 106, 0, .007) 14px,
            rgba(255, 106, 0, .007) 15px
        );
    mix-blend-mode: multiply;
    pointer-events: none;
}

.icb-faq-contact-wrap {
    position: relative;
    z-index: 1;
    width: min(100%, 1680px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: clamp(36px, 4.5vh, 52px);
}

.icb-faq-contact-head {
    text-align: center;
    max-width: min(100%, 720px);
    margin: 0 auto;
    margin-bottom: 40px;
}

.icb-faq-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 12px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 13px;
    font-weight: 400;
    letter-spacing: 1.2px;
    line-height: 1.2;
    text-transform: uppercase;
    color: var(--primary-orange);
}

.icb-faq-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary-orange);
    box-shadow: 0 0 12px rgba(255, 106, 0, .55);
    flex-shrink: 0;
}

.icb-faq-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(2rem, 4.6vw, 4.75rem);
    font-weight: 400;
    line-height: 1.06;
    letter-spacing: -1.2px;
    color: var(--primary-black);
}

.icb-faq-title-line {
    display: block;
}

.icb-faq-title-line--accent {
    color: var(--primary-orange);
}

.icb-faq-subtitle {
    margin: clamp(14px, 2vh, 18px) auto 0;
    max-width: 560px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(.98rem, 1vw, 1.08rem);
    font-weight: 400;
    line-height: 1.55;
    letter-spacing: 0.2px;
    color: var(--primary-black);
}

.icb-faq-desc {
    margin: clamp(10px, 1.4vh, 14px) auto 0;
    max-width: 560px;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.94rem, 1vw, 1.05rem);
    font-weight: 300;
    line-height: 1.68;
    letter-spacing: 1.2px;
    color: var(--muted-text);
}

.icb-faq-contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(28px, 4vw, 48px);
    align-items: stretch;
}

.icb-faq-panel,
.icb-faq-form-panel {
    min-width: 0;
}

.icb-faq-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: 100%;
}

.faq-accordion-item {
    position: relative;
    border-radius: 18px;
    background: rgba(255, 255, 255, .94);
    border: 1px solid rgba(3, 3, 3, .07);
    box-shadow:
        0 1px 2px rgba(3, 3, 3, .03),
        0 8px 24px rgba(3, 3, 3, .04);
    overflow: hidden;
    isolation: isolate;
    transition:
        border-color .35s var(--fc-ease),
        box-shadow .35s var(--fc-ease),
        background .35s var(--fc-ease);
}

.faq-accordion-item.is-active {
    background: #fff;
    border-color: transparent;
    box-shadow:
        0 12px 36px rgba(255, 106, 0, .1),
        0 4px 16px rgba(3, 3, 3, .05);
}

.faq-accordion-item.is-switching::before {
    opacity: 0 !important;
}

.faq-accordion-item.is-active::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.5px;
    background: linear-gradient(135deg, #ff6a00, #ffc47a, transparent, #ff6a00, #ff8a1f);
    background-size: 220% auto;
    animation: fcBorderRun 4s linear infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    pointer-events: none;
    z-index: 0;
}

.faq-accordion-trigger {
    position: relative;
    z-index: 1;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: clamp(16px, 2vw, 20px) clamp(18px, 2.2vw, 24px);
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.faq-accordion-question {
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(.95rem, 1.05vw, 1.05rem);
    font-weight: 400;
    line-height: 1.45;
    letter-spacing: 0.2px;
    color: var(--primary-black);
    transition: color .3s var(--fc-ease);
}

.faq-icon-wrapper {
    position: relative;
    z-index: 1;
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    border: 1px solid rgba(3, 3, 3, .08);
    background: #fff;
    color: var(--muted-text);
    box-shadow:
        0 2px 6px rgba(3, 3, 3, .06),
        0 8px 18px rgba(255, 106, 0, .08),
        inset 0 1px 0 rgba(255, 255, 255, 1);
    transition:
        color .35s var(--fc-ease),
        border-color .35s var(--fc-ease),
        box-shadow .35s var(--fc-ease),
        background .35s var(--fc-ease);
}

.faq-icon-plus {
    width: 14px;
    height: 14px;
}

.faq-accordion-item.is-active .faq-icon-wrapper {
    color: var(--primary-orange);
    border-color: rgba(255, 106, 0, .28);
    background: rgba(255, 106, 0, .06);
    box-shadow:
        0 4px 12px rgba(255, 106, 0, .14),
        0 10px 24px rgba(255, 106, 0, .1),
        inset 0 1px 0 rgba(255, 255, 255, .9);
}

.faq-accordion-content {
    position: relative;
    z-index: 1;
    overflow: hidden;
    height: 0;
}

.faq-accordion-content p {
    margin: 0;
    padding: 0 clamp(18px, 2.2vw, 24px) clamp(18px, 2.2vw, 22px);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.88rem, 2vw, .94rem);
    font-weight: 300;
    line-height: 1.68;
    letter-spacing: .4px;
    color: #000000;
}

.icb-faq-form-panel {
    display: flex;
    align-items: stretch;
}

.icb-faq-form-card {
    position: relative;
    width: 100%;
    padding: clamp(28px, 3vw, 40px);
    border-radius: 20px;
    background: rgba(255, 255, 255, .96);
    border: 1px solid transparent;
    box-shadow:
        0 1px 2px rgba(3, 3, 3, .03),
        0 16px 48px rgba(3, 3, 3, .06),
        0 24px 56px rgba(255, 106, 0, .07);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    isolation: isolate;
    transform-style: preserve-3d;
}

.icb-faq-form-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.5px;
    background: linear-gradient(135deg, #ff6a00, #ffc47a, transparent, #ff6a00, #ff8a1f);
    background-size: 220% auto;
    animation: fcBorderRun 5s linear infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    pointer-events: none;
    z-index: 0;
}

.icb-faq-form-head,
.icb-faq-form {
    position: relative;
    z-index: 1;
}

.icb-faq-form-kicker {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 10px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: 13px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: var(--primary-orange);
}

.icb-faq-form-kicker::after {
    content: "";
    width: 48px;
    height: 1px;
    background: linear-gradient(90deg, var(--primary-orange), transparent);
}

.icb-faq-form-title {
    margin: 0;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(1.35rem, 2.8vw, 2.65rem);
    font-weight: 400;
    line-height: 1.12;
    letter-spacing: 0px;
    color: var(--primary-black);
}

.icb-faq-form-desc {
    margin: 10px 0 0;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.94rem, 1vw, 1.05rem);
    font-weight: 300;
    line-height: 1.68;
    letter-spacing: 1.2px;
    color: var(--muted-text);
}

.icb-faq-form-head {
    margin-bottom: clamp(22px, 2.5vh, 28px);
}

.icb-faq-form {
    display: grid;
    gap: 14px;
}

.icb-faq-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

.icb-fc-input {
    width: 100%;
    min-width: 0;
    height: 52px;
    padding: 0 16px;
    border: 1px solid rgba(3, 3, 3, .1);
    border-radius: 10px;
    background: #fafafa;
    color: var(--primary-black);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: .92rem;
    line-height: 1;
    outline: none;
    transition:
        border-color .28s var(--fc-ease),
        box-shadow .28s var(--fc-ease),
        background .28s var(--fc-ease);
}

.icb-fc-input::placeholder {
    color: rgba(3, 3, 3, .42);
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
}

.icb-fc-input:hover {
    border-color: rgba(255, 106, 0, .28);
    background: #fff;
}

.icb-fc-input:focus {
    border-color: rgba(255, 106, 0, .55);
    background: #fff;
    box-shadow: 0 0 0 3px rgba(255, 106, 0, .1);
}

.icb-fc-select-wrap {
    position: relative;
}

.icb-fc-select {
    appearance: none;
    -webkit-appearance: none;
    padding-right: 44px;
    cursor: pointer;
    color: rgba(3, 3, 3, .72);
}

.icb-fc-select option {
    background: #fff;
    color: var(--primary-black);
}

.icb-fc-select-wrap svg {
    position: absolute;
    right: 16px;
    top: 50%;
    width: 16px;
    height: 16px;
    transform: translateY(-50%);
    color: var(--muted-text);
    pointer-events: none;
}

.icb-fc-textarea {
    height: 118px;
    min-height: 118px;
    padding-top: 14px;
    resize: vertical;
    line-height: 1.5;
}

.icb-fc-submit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    width: 100%;
    height: 56px;
    margin-top: 6px;
    border: 1px solid var(--primary-orange);
    border-radius: 10px;
    background: #fff;
    color: var(--primary-orange);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: .92rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow:
        0 4px 16px rgba(255, 106, 0, .12),
        0 12px 32px rgba(3, 3, 3, .05),
        inset 0 1px 0 rgba(255, 255, 255, 1);
    transition:
        color .3s var(--fc-ease),
        background .3s var(--fc-ease),
        box-shadow .3s var(--fc-ease),
        transform .3s var(--fc-ease);
}

.icb-fc-submit svg {
    width: 18px;
    height: 18px;
    transition: transform .3s var(--fc-ease);
}

.icb-fc-submit:hover {
    background: var(--primary-orange);
    color: #fff;
    transform: translateY(-1px);
    box-shadow:
        0 8px 24px rgba(255, 106, 0, .24),
        0 16px 40px rgba(255, 106, 0, .12);
}

.icb-fc-submit:hover svg {
    transform: translateX(4px);
}

.icb-faq-trust {
    width: 100%;
}

.icb-faq-trust-panel {
    position: relative;
    overflow: hidden;
    border-radius: clamp(16px, 2vw, 22px);
    padding: clamp(22px, 2.8vw, 32px) clamp(20px, 3vw, 36px);
    background:
        linear-gradient(145deg, #101010 0%, #030303 42%, #1a0d04 100%);
    border: 1px solid rgba(255, 106, 0, .2);
    box-shadow:
        0 24px 64px rgba(3, 3, 3, .24),
        0 0 48px rgba(255, 106, 0, .08),
        inset 0 1px 0 rgba(255, 255, 255, .06);
}

.icb-faq-trust-panel::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 90% 70% at 50% -20%, rgba(255, 106, 0, .16) 0%, transparent 58%),
        radial-gradient(ellipse 60% 50% at 50% 100%, rgba(255, 106, 0, .1) 0%, transparent 55%);
    opacity: .85;
}

.icb-faq-trust-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    background:
        radial-gradient(ellipse 72% 110% at 0% 50%, rgba(255, 106, 0, .24) 0%, transparent 62%),
        radial-gradient(ellipse 55% 90% at 22% 50%, rgba(255, 120, 40, .14) 0%, transparent 58%),
        radial-gradient(ellipse 55% 90% at 50% 50%, rgba(255, 106, 0, .1) 0%, transparent 62%),
        radial-gradient(ellipse 55% 90% at 78% 50%, rgba(255, 120, 40, .14) 0%, transparent 58%),
        radial-gradient(ellipse 72% 110% at 100% 50%, rgba(255, 106, 0, .24) 0%, transparent 62%),
        linear-gradient(rgba(255, 106, 0, .06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 106, 0, .06) 1px, transparent 1px);
    background-size: auto, auto, auto, auto, auto, 44px 44px, 44px 44px;
    opacity: 1;
}

.icb-faq-trust-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(10px, 1.4vw, 20px);
    align-items: center;
    width: 100%;
}

.icb-faq-trust-item {
    position: relative;
    display: grid;
    grid-template-columns: 48px 1fr;
    align-items: center;
    gap: clamp(12px, 1.4vw, 16px);
    min-width: 0;
    padding: clamp(10px, 1.2vw, 14px) clamp(8px, 1.2vw, 16px);
}

.icb-faq-trust-item + .icb-faq-trust-item::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: clamp(44px, 5vw, 56px);
    background: linear-gradient(180deg, transparent, rgba(255, 106, 0, .28), transparent);
}

.icb-faq-trust-icon {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--primary-orange);
    filter: drop-shadow(0 0 14px rgba(255, 106, 0, .32));
}

.icb-faq-trust-icon svg {
    width: 44px;
    height: 44px;
}

.icb-faq-trust-icon--cta {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 1px solid rgba(255, 106, 0, .32);
    background: rgba(255, 106, 0, .08);
    box-shadow:
        0 0 20px rgba(255, 106, 0, .18),
        inset 0 1px 0 rgba(255, 255, 255, .08);
    filter: none;
}

.icb-faq-trust-icon--cta svg {
    width: 18px;
    height: 18px;
}

.icb-faq-trust-copy {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}

.icb-faq-trust-item--cta .icb-faq-trust-copy {
    min-width: 0;
}

.icb-faq-trust-item--cta .icb-faq-trust-title,
.icb-faq-trust-item--cta .icb-faq-trust-text,
.icb-faq-trust-item--cta .icb-faq-trust-link {
    opacity: 1;
    visibility: visible;
}

.icb-faq-trust-title {
    display: block;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(.92rem, 1vw, 1.02rem);
    font-weight: 400;
    line-height: 1.35;
    letter-spacing: 0.4px;
    color: #fff;
}

.icb-faq-trust-text {
    display: block;
    margin-top: 3px;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(.82rem, .88vw, .9rem);
    font-weight: 300;
    line-height: 1.5;
    letter-spacing: 0.2px;
    color: rgba(255, 255, 255, .68);
}

.icb-faq-trust-link {
    display: inline-block;
    margin-top: 8px;
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(.84rem, .9vw, .92rem);
    letter-spacing: 0.2px;
    color: var(--primary-orange);
    transition: opacity .25s var(--fc-ease), transform .25s var(--fc-ease);
}

.icb-faq-trust-link:hover {
    opacity: .85;
    transform: translateX(3px);
}

.icb-keyword-section {
    width: 100%;
    margin-top: clamp(36px, 4.5vh, 56px);
    margin-bottom: clamp(32px, 4vh, 48px);
}

.icb-keyword-panel {
    position: relative;
    z-index: 1;
    padding: clamp(28px, 3.2vw, 40px);
    border-radius: 22px;
    background:
        linear-gradient(165deg, rgba(255, 255, 255, 0.99) 0%, rgba(255, 252, 248, 0.96) 52%, rgba(255, 255, 255, 0.94) 100%);
    border: 1px solid rgba(255, 255, 255, 0.92);
    box-shadow:
        0 1px 2px rgba(3, 3, 3, 0.04),
        0 14px 36px rgba(3, 3, 3, 0.06),
        0 28px 56px rgba(255, 106, 0, 0.09),
        0 4px 0 rgba(255, 255, 255, 0.85) inset,
        0 -1px 0 rgba(3, 3, 3, 0.04) inset;
    transform: perspective(1400px) translateY(-6px) rotateX(1.4deg);
    transform-style: preserve-3d;
    isolation: isolate;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

.icb-keyword-panel::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.5px;
    background: linear-gradient(135deg, rgba(255, 106, 0, 0.55), rgba(255, 196, 122, 0.45), transparent 42%, rgba(255, 106, 0, 0.35), rgba(255, 138, 31, 0.5));
    background-size: 220% auto;
    animation: fcBorderRun 6s linear infinite;
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask:
        linear-gradient(#fff 0 0) content-box,
        linear-gradient(#fff 0 0);
    mask-composite: exclude;
    pointer-events: none;
    z-index: 0;
}

.icb-keyword-panel::after {
    content: "";
    position: absolute;
    left: 8%;
    right: 8%;
    bottom: -20px;
    height: 36px;
    border-radius: 50%;
    background: radial-gradient(ellipse at center, rgba(255, 106, 0, 0.2) 0%, transparent 72%);
    filter: blur(14px);
    z-index: -1;
    pointer-events: none;
}

.icb-keyword-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: clamp(20px, 2.5vw, 32px);
    align-items: stretch;
}

.icb-keyword-col {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
}

.icb-keyword-heading {
    margin: 0 0 clamp(12px, 1.6vh, 16px);
    padding: 0 clamp(2px, 0.4vw, 4px);
    font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
    font-size: clamp(0.88rem, 0.94vw, 0.98rem);
    font-weight: 400;
    line-height: 1.35;
    letter-spacing: 0.2px;
    color: var(--primary-black);
}

.icb-keyword-viewport {
    position: relative;
    flex: 1 1 auto;
    height: clamp(220px, 26vh, 268px);
    overflow: hidden auto;
    overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    border: 1px solid rgba(3, 3, 3, 0.05);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.55);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.95),
        inset 0 -8px 16px rgba(3, 3, 3, 0.02),
        0 1px 2px rgba(3, 3, 3, 0.02);
    scrollbar-width: thin;
    scrollbar-color: rgba(3, 3, 3, 0.14) transparent;
}

.icb-keyword-viewport:focus-visible {
    outline: 2px solid rgba(255, 106, 0, 0.35);
    outline-offset: 2px;
}

.icb-keyword-viewport::-webkit-scrollbar {
    width: 3px;
}

.icb-keyword-viewport::-webkit-scrollbar-track {
    background: transparent;
    margin: 8px 0;
}

.icb-keyword-viewport::-webkit-scrollbar-thumb {
    background: rgba(3, 3, 3, 0.12);
    border-radius: 999px;
}

.icb-keyword-viewport::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 106, 0, 0.28);
}

.icb-keyword-viewport::after {
    content: "";
    position: sticky;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 28px;
    margin-top: -28px;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.92) 88%);
}

.icb-keyword-list {
    list-style: none;
    margin: 0;
    padding: clamp(12px, 1.4vw, 16px) clamp(14px, 1.6vw, 18px) clamp(18px, 2vh, 22px);
}

.icb-keyword-list li + li {
    margin-top: clamp(10px, 1.2vh, 13px);
}

.icb-keyword-list a {
    display: block;
    font-family: 'NeueHaasDisplay-Thin', sans-serif !important;
    font-size: clamp(0.82rem, 0.88vw, 0.92rem);
    font-weight: 300;
    line-height: 1.55;
    letter-spacing: 0.6px;
    color: var(--muted-text);
    text-decoration: none;
    transition: color 0.22s ease, transform 0.22s ease;
}

.icb-keyword-list a:hover {
    color: var(--primary-orange);
    transform: translateX(2px);
}

@media (max-width: 1100px) {
    .icb-faq-contact-grid {
        grid-template-columns: 1fr;
        gap: clamp(32px, 4vh, 40px);
    }

    .icb-keyword-section {
        margin-top: clamp(28px, 3.5vh, 40px);
        margin-bottom: clamp(24px, 3vh, 36px);
    }

    .icb-keyword-panel {
        padding: clamp(22px, 3vw, 28px);
        transform: perspective(1200px) translateY(-4px) rotateX(0.8deg);
    }

    .icb-keyword-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: clamp(24px, 3vw, 28px);
    }

    .icb-keyword-viewport {
        height: clamp(200px, 24vh, 240px);
    }

    .icb-faq-trust-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: clamp(16px, 2vw, 22px);
    }

    .icb-faq-trust-item--cta {
        grid-column: 1 / -1;
        padding-bottom: clamp(14px, 2vw, 18px);
        margin-bottom: clamp(4px, 1vw, 8px);
        border-bottom: 1px solid rgba(255, 106, 0, .2);
    }

    .icb-faq-trust-item--cta::after {
        display: none;
    }

    .icb-faq-trust-item + .icb-faq-trust-item::before {
        display: none;
    }
}

@media (max-width: 768px) {
    .icb-faq-contact-section {
        padding: clamp(56px, 8vh, 80px) clamp(14px, 4vw, 20px) clamp(48px, 6vh, 64px);
    }

    .icb-faq-title {
        font-size: clamp(1.75rem, 6.5vw, 2.35rem);
    }

    .icb-faq-form-row {
        grid-template-columns: 1fr;
    }

    .icb-keyword-section {
        margin-top: clamp(24px, 3vh, 32px);
        margin-bottom: clamp(20px, 2.5vh, 28px);
    }

    .icb-keyword-panel {
        padding: clamp(18px, 4vw, 24px);
        border-radius: 18px;
        transform: none;
    }

    .icb-keyword-panel::after {
        bottom: -14px;
        height: 28px;
    }

    .icb-keyword-grid {
        grid-template-columns: 1fr;
        gap: clamp(20px, 3vh, 24px);
    }

    .icb-keyword-viewport {
        height: clamp(188px, 22vh, 220px);
    }

    .icb-faq-trust-grid {
        grid-template-columns: 1fr;
        gap: 0;
    }

    .icb-faq-trust-panel {
        padding: clamp(18px, 4vw, 24px) clamp(16px, 4vw, 20px);
    }

    .icb-faq-trust-item {
        padding: clamp(14px, 3vw, 18px) 4px;
    }

    .icb-faq-trust-item--cta {
        margin-bottom: 0;
        padding-bottom: clamp(14px, 3vw, 18px);
        border-bottom: 1px solid rgba(255, 106, 0, .16);
    }

    .icb-faq-trust-item + .icb-faq-trust-item::before {
        display: none;
    }

    .icb-faq-trust-item + .icb-faq-trust-item:not(.icb-faq-trust-item--cta) {
        border-top: 1px solid rgba(255, 106, 0, .12);
    }
}

@media (prefers-reduced-motion: reduce) {
    .faq-accordion-item.is-active::before,
    .icb-faq-form-card::before,
    .icb-keyword-panel::before {
        animation: none;
    }

    .icb-keyword-panel {
        transform: none;
    }

    .faq-accordion-item,
    .faq-icon-wrapper,
    .icb-fc-submit,
    .icb-fc-input {
        transition: none !important;
    }
}

/* FAQ + Contact end */
    /* footer */
    /* Custom UI Underline Animation */
        .hover-underline-anim {
            position: relative;
            display: inline-block;
        }
        .hover-underline-anim::after {
            content: '';
            position: absolute;
            width: 100%;
            transform: scaleX(0);
            height: 1px;
            bottom: -2px;
            left: 0;
            background-color: #FF5A00;
            transform-origin: bottom right;
            transition: transform 0.4s cubic-bezier(0.86, 0, 0.07, 1);
        }
        .hover-underline-anim:hover::after {
            transform: scaleX(1);
            transform-origin: bottom left;
        }

        /* Glass Input Autofill Override */
        input:-webkit-autofill,
        input:-webkit-autofill:hover, 
        input:-webkit-autofill:focus, 
        input:-webkit-autofill:active{
            -webkit-box-shadow: 0 0 0 30px #0a0a0a inset !important;
            -webkit-text-fill-color: white !important;
            transition: background-color 5000s ease-in-out 0s;
        }

        .icb-reference-footer {
            --icb-footer-orange: var(--primary-orange, #ff6a00);
            --icb-footer-soft-orange: rgba(255, 106, 0, 0.78);
            --icb-footer-white: #fafafa;
            --icb-footer-copy: rgba(255, 255, 255, 0.9);
            --icb-footer-muted: rgba(255, 255, 255, 0.62);
            --icb-footer-line: rgba(255, 106, 0, 0.32);
            position: relative;
            z-index: 1000;
            isolation: isolate;
            width: 100%;
            overflow: hidden;
            background:
                linear-gradient(155deg, #0c0603 0%, #050403 38%, #030303 62%, #0a0502 100%);
            color: var(--icb-footer-white);
            padding: clamp(112px, calc(9vh + 40px), 152px) 0 clamp(16px, calc(5vh - 20px), 22px);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            box-shadow: inset 0 1px 0 rgba(255, 106, 0, 0.06);
        }

        .icb-footer-bg {
            position: absolute;
            inset: 0;
            pointer-events: none;
            z-index: 0;
            background:
                radial-gradient(ellipse 85% 65% at 50% 0%, rgba(255, 106, 0, 0.14) 0%, rgba(255, 120, 40, 0.05) 28%, transparent 68%),
                radial-gradient(ellipse 55% 48% at 18% 55%, rgba(255, 106, 0, 0.09) 0%, transparent 62%),
                radial-gradient(ellipse 55% 48% at 82% 48%, rgba(255, 106, 0, 0.09) 0%, transparent 62%),
                radial-gradient(ellipse 40% 35% at 50% 72%, rgba(255, 140, 50, 0.06) 0%, transparent 70%),
                conic-gradient(from 210deg at 50% 35%, transparent 0deg, rgba(255, 106, 0, 0.03) 60deg, transparent 120deg, rgba(255, 106, 0, 0.02) 220deg, transparent 300deg),
                linear-gradient(rgba(255, 106, 0, 0.032) 1px, transparent 1px),
                linear-gradient(90deg, rgba(255, 106, 0, 0.032) 1px, transparent 1px);
            background-size: auto, auto, auto, auto, auto, 48px 48px, 48px 48px;
            opacity: 0.78;
            animation: icbFooterGlow 14s ease-in-out infinite alternate;
        }

        @keyframes icbFooterGlow {
            0% {
                filter: brightness(0.96) saturate(0.95);
                opacity: 0.72;
            }
            100% {
                filter: brightness(1) saturate(1);
                opacity: 0.82;
            }
        }

        @media (prefers-reduced-motion: reduce) {
            .icb-footer-bg {
                animation: none;
            }
        }

        .icb-reference-footer::before,
        .icb-reference-footer::after {
            content: "";
            position: absolute;
            pointer-events: none;
            z-index: 0;
        }

        .icb-reference-footer::before {
            inset: 0;
            background:
                radial-gradient(circle at 50% 12%, rgba(255, 106, 0, 0.07) 0%, transparent 42%),
                radial-gradient(circle at 8% 7%, rgba(255, 255, 255, 0.02), transparent 18%),
                radial-gradient(circle at 91% 4%, rgba(255, 106, 0, 0.04), transparent 22%),
                linear-gradient(180deg, rgba(255, 106, 0, 0.03), transparent 32%);
            opacity: 0.85;
        }

        .icb-reference-footer::after {
            left: 0;
            right: 0;
            top: 0;
            height: 1px;
            background: linear-gradient(90deg, transparent, rgba(255, 106, 0, 0.32), rgba(255, 180, 80, 0.18), rgba(255, 106, 0, 0.32), transparent);
            box-shadow: 0 0 12px rgba(255, 106, 0, 0.18);
        }

        .icb-footer-shell {
            position: relative;
            z-index: 1;
            width: min(100%, 1680px);
            margin: 0 auto;
            padding: 0 clamp(16px, 2.5vw, 32px);
            pointer-events: auto;
        }

        .icb-reference-footer a,
        .icb-reference-footer button,
        .icb-reference-footer input {
            cursor: pointer;
        }

        .icb-footer-top {
            display: grid;
            grid-template-columns: minmax(240px, 1.4fr) repeat(4, minmax(0, 1fr));
            gap: clamp(28px, 3.5vw, 48px);
            align-items: start;
            padding-bottom: clamp(16px, calc(4.5vh - 20px), 32px);
        }

        .icb-footer-brand {
            position: relative;
            min-height: auto;
            max-width: 420px;
            padding-bottom: clamp(80px, calc(12vh - 20px), 108px);
        }

        .icb-footer-logo {
            display: inline-flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 10px;
            text-decoration: none;
            line-height: 1;
        }

        .icb-footer-logo-img {
            display: block;
            width: min(100%, 156px);
            height: auto;
            object-fit: contain;
            filter: drop-shadow(0 0 18px rgba(255, 255, 255, 0.08));
        }

        .icb-footer-logo-word {
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(1.35rem, 1.8vw, 1.65rem);
            font-weight: 400;
            letter-spacing: 0.28em;
            text-transform: uppercase;
            color: var(--icb-footer-orange);
            text-shadow: 0 0 18px rgba(255, 106, 0, 0.28);
        }

        .icb-logo-icb,
        .icb-logo-digital {
            display: none;
        }

        .icb-footer-brand-rule {
            position: relative;
            width: min(100%, 280px);
            height: 1px;
            margin-top: clamp(24px, 3vh, 32px);
            background: linear-gradient(90deg, var(--icb-footer-orange) 0%, rgba(255, 106, 0, 0.35) 45%, transparent 100%);
        }

        .icb-footer-brand-rule::before,
        .icb-footer-brand-rule::after {
            content: "";
            position: absolute;
            top: 50%;
            transform: translate(-50%, -50%);
            border-radius: 999px;
        }

        .icb-footer-brand-rule::before {
            left: 61px;
            width: 8px;
            height: 8px;
            background: #fff;
            box-shadow: 0 0 9px #fff, 0 0 22px var(--icb-footer-orange), 0 0 42px rgba(255, 115, 0, 0.95);
        }

        .icb-footer-brand-rule::after {
            left: 61px;
            width: 108px;
            height: 18px;
            background: radial-gradient(ellipse at center, rgba(255, 115, 0, 0.46), transparent 68%);
            filter: blur(3px);
        }

        .icb-footer-tagline {
            margin: clamp(18px, 2.2vh, 24px) 0 0;
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.76rem, 0.82vw, 0.84rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1.4;
            text-transform: uppercase;
            color: var(--icb-footer-white);
        }

        .icb-footer-brand-copy {
            max-width: 36ch;
            margin: clamp(14px, 1.8vh, 18px) 0 0;
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.94rem, 1vw, 1.02rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1.72;
            color: var(--icb-footer-copy);
        }

        .icb-footer-mascot {
            position: absolute;
            left: clamp(24px, 4vw, 48px);
            bottom: 0;
            width: 180px;
            height: 112px;
            background-image: url("img/icb_footer2.png");
            background-repeat: no-repeat;
            background-position: -175px -505px;
            background-size: 1672px 941px;
            mix-blend-mode: screen;
            filter: drop-shadow(0 -4px 24px rgba(255, 106, 0, 0.16));
            opacity: 0.85;
        }

        .icb-footer-column,
        .icb-footer-contact {
            position: relative;
            padding-top: 0;
            padding-left: clamp(16px, 2vw, 28px);
            border-left: 1px solid var(--icb-footer-line);
        }

        .icb-footer-column.has-divider::after {
            display: none;
        }

        .icb-footer-heading {
            display: flex;
            align-items: center;
            gap: 12px;
            margin: 0;
            color: var(--icb-footer-orange);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.82rem, 0.88vw, 0.88rem);
            line-height: 1.2;
            font-weight: 400;
            letter-spacing: 1.2px;
            text-transform: uppercase;
            text-shadow: 0 0 18px rgba(255, 106, 0, 0.25);
        }

        .icb-footer-heading::after {
            content: "";
            flex: 1 1 auto;
            max-width: 48px;
            height: 1px;
            background: linear-gradient(90deg, var(--icb-footer-orange), transparent);
            box-shadow: 0 0 8px rgba(255, 106, 0, 0.35);
        }

        .icb-footer-links,
        .icb-footer-contact-list {
            list-style: none;
            padding: 0;
            margin: clamp(22px, 2.5vh, 28px) 0 0;
        }

        .icb-footer-links li + li {
            margin-top: 14px;
        }

        .icb-footer-link {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 10px;
            width: 100%;
            color: var(--icb-footer-copy);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.94rem, 1vw, 1.02rem);
            font-weight: 400;
            line-height: 1.6;
            letter-spacing: 0.2px;
            text-decoration: none;
            transition: color 0.24s ease, transform 0.24s ease;
        }

        .icb-footer-link svg,
        .icb-footer-arrow {
            flex: 0 0 auto;
            width: 15px;
            height: 15px;
            color: var(--icb-footer-orange);
            opacity: 0.82;
            transform: translateX(0);
            filter: drop-shadow(0 0 10px rgba(255, 106, 0, 0.55));
            transition: opacity 0.24s ease, transform 0.24s ease, filter 0.24s ease;
        }

        .icb-footer-link:hover {
            color: #fff;
            transform: translateX(2px);
        }

        .icb-footer-link:hover .icb-footer-arrow {
            opacity: 1;
            transform: translateX(4px);
            filter: drop-shadow(0 0 14px rgba(255, 106, 0, 0.85));
        }

        .icb-footer-contact-list {
            margin-top: clamp(22px, 2.5vh, 28px);
        }

        .icb-footer-contact-list li + li {
            margin-top: 16px;
        }

        .icb-footer-contact-item {
            display: grid;
            grid-template-columns: 28px 1fr;
            column-gap: 14px;
            align-items: start;
            color: var(--icb-footer-copy);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.94rem, 1vw, 1.02rem);
            font-weight: 400;
            line-height: 1.6;
            letter-spacing: 0.2px;
            text-decoration: none;
            transition: color 0.24s ease;
        }

        .icb-footer-contact-item:hover {
            color: #fff;
        }

        .icb-footer-contact-icon {
            color: var(--icb-footer-orange);
            width: 26px;
            height: 26px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            filter: drop-shadow(0 0 9px rgba(255, 115, 0, 0.28));
        }

        .icb-footer-contact-icon svg {
            width: 24px;
            height: 24px;
        }

        .icb-footer-strategy {
            display: grid;
            grid-template-columns: 1fr 37px;
            align-items: center;
            gap: 14px;
            width: 100%;
            max-width: 280px;
            min-height: 72px;
            margin-top: clamp(24px, 3vh, 32px);
            padding: 14px 14px 14px 16px;
            border: 1px solid rgba(255, 106, 0, 0.45);
            border-radius: 10px;
            background: rgba(255, 106, 0, 0.04);
            color: #fff;
            text-decoration: none;
            box-shadow: inset 0 0 24px rgba(255, 106, 0, 0.03), 0 0 24px rgba(255, 106, 0, 0.06);
            transition: border-color 0.24s ease, box-shadow 0.24s ease, transform 0.24s ease;
        }

        .icb-footer-strategy span {
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.72rem, 0.78vw, 0.8rem);
            line-height: 1.45;
            font-weight: 400;
            letter-spacing: 0.2px;
            text-transform: uppercase;
        }

        .icb-footer-strategy-icon,
        .icb-newsletter-button {
            border: 1px solid rgba(255, 115, 0, 0.72);
            color: var(--icb-footer-orange);
            background: transparent;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            transition: background 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
        }

        .icb-footer-strategy-icon {
            width: 37px;
            height: 37px;
            border-radius: 5px;
        }

        .icb-footer-strategy:hover {
            transform: translateY(-2px);
            border-color: var(--icb-footer-orange);
            box-shadow: 0 0 28px rgba(255, 115, 0, 0.16);
        }

        .icb-footer-strategy:hover .icb-footer-strategy-icon,
        .icb-newsletter-button:hover {
            color: #000;
            background: var(--icb-footer-orange);
            box-shadow: 0 0 18px rgba(255, 115, 0, 0.35);
        }

        .icb-footer-divider {
            position: relative;
            height: 1px;
            width: 100%;
            background: linear-gradient(90deg, transparent 0%, rgba(255, 115, 0, 0.72) 5%, rgba(255, 115, 0, 0.26) 20%, rgba(255, 115, 0, 0.16) 80%, rgba(255, 115, 0, 0.54) 94%, transparent 100%);
        }

        .icb-footer-divider::before,
        .icb-footer-divider::after {
            content: "";
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%, -50%);
            border-radius: 999px;
        }

        .icb-footer-divider::before {
            width: 9px;
            height: 9px;
            background: #fff;
            box-shadow: 0 0 9px #fff, 0 0 22px var(--icb-footer-orange), 0 0 48px rgba(255, 115, 0, 0.95);
        }

        .icb-footer-divider::after {
            width: 178px;
            height: 24px;
            background: radial-gradient(ellipse at center, rgba(255, 115, 0, 0.42), transparent 66%);
            filter: blur(4px);
        }

        .icb-footer-mid {
            display: grid;
            grid-template-columns: minmax(240px, 0.95fr) minmax(300px, 1.15fr) minmax(300px, 1.1fr);
            gap: clamp(32px, 4vw, 72px);
            min-height: auto;
            padding: clamp(36px, 4.5vh, 48px) 0 clamp(20px, 2.5vh, 28px);
            align-items: start;
        }

        .icb-social-title,
        .icb-newsletter-title {
            margin: 0;
            text-transform: uppercase;
            line-height: 1.2;
            font-weight: 400;
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            letter-spacing: 1.2px;
        }

        .icb-social-title {
            color: var(--icb-footer-orange);
            font-size: clamp(0.82rem, 0.88vw, 0.92rem);
        }

        .icb-social-list {
            display: flex;
            align-items: center;
            gap: clamp(14px, 1.6vw, 22px);
            margin-top: clamp(18px, 2.2vh, 24px);
        }

        .icb-social-link {
            width: 56px;
            height: 56px;
            border: 1px solid rgba(255, 255, 255, 0.13);
            border-radius: 7px;
            background: rgba(255, 255, 255, 0.012);
            color: rgba(255, 255, 255, 0.86);
            display: inline-flex;
            align-items: center;
            justify-content: center;
            text-decoration: none;
            transition: border-color 0.24s ease, color 0.24s ease, background 0.24s ease, transform 0.24s ease;
        }

        .icb-social-link svg {
            width: 24px;
            height: 24px;
        }

        .icb-social-link:hover {
            color: #000;
            border-color: var(--icb-footer-orange);
            background: var(--icb-footer-orange);
            transform: translateY(-2px);
        }

        .icb-newsletter-title {
            color: rgba(255, 255, 255, 0.92);
            font-size: clamp(0.82rem, 0.88vw, 0.92rem);
        }

        .icb-newsletter-form {
            position: relative;
            display: flex;
            align-items: center;
            width: 100%;
            max-width: 486px;
            height: 57px;
            margin-top: clamp(18px, 2.2vh, 24px);
        }

        .icb-newsletter-form input {
            width: 100%;
            height: 100%;
            border: 1px solid rgba(255, 255, 255, 0.2);
            border-radius: 7px;
            background: rgba(0, 0, 0, 0.28);
            color: #fff;
            padding: 0 62px 0 20px;
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.94rem, 1vw, 1rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1;
            outline: none;
            transition: border-color 0.24s ease, box-shadow 0.24s ease;
        }

        .icb-newsletter-form input::placeholder {
            color: rgba(255, 255, 255, 0.55);
            letter-spacing: 0.2px;
        }

        .icb-newsletter-form input:focus {
            border-color: rgba(255, 115, 0, 0.78);
            box-shadow: 0 0 24px rgba(255, 115, 0, 0.11);
        }

        .icb-newsletter-button {
            position: absolute;
            right: 13px;
            top: 50%;
            width: 36px;
            height: 36px;
            transform: translateY(-50%);
            border-radius: 5px;
            cursor: pointer;
        }

        .icb-newsletter-note {
            margin: 13px 0 0;
            color: var(--icb-footer-muted);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.86rem, 0.92vw, 0.94rem);
            font-weight: 400;
            letter-spacing: 0.4px;
            line-height: 1.6;
        }

        .icb-footer-quickstart {
            justify-self: stretch;
            width: 100%;
            min-width: 0;
        }

        .icb-footer-quickstart-title {
            margin: 0;
            color: rgba(255, 255, 255, 0.92);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.82rem, 0.88vw, 0.92rem);
            font-weight: 400;
            line-height: 1.2;
            letter-spacing: 1.2px;
            text-transform: uppercase;
        }

        .icb-footer-quickstart-form {
            position: relative;
            display: flex;
            align-items: center;
            width: 100%;
            height: 57px;
            margin-top: clamp(18px, 2.2vh, 24px);
        }

        .icb-footer-quickstart-select {
            width: 100%;
            height: 100%;
            border: 1px solid rgba(255, 255, 255, 0.2);
            border-radius: 7px;
            background: rgba(0, 0, 0, 0.28);
            color: #fff;
            padding: 0 62px 0 20px;
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.94rem, 1vw, 1rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1;
            outline: none;
            appearance: none;
            cursor: pointer;
            transition: border-color 0.24s ease, box-shadow 0.24s ease;
        }

        .icb-footer-quickstart-select:focus {
            border-color: rgba(255, 115, 0, 0.78);
            box-shadow: 0 0 24px rgba(255, 115, 0, 0.11);
        }

        .icb-footer-quickstart-select option {
            color: #111;
            background: #fff;
        }

        .icb-footer-quickstart-button {
            position: absolute;
            right: 13px;
            top: 50%;
            width: 36px;
            height: 36px;
            transform: translateY(-50%);
            border-radius: 5px;
            border: 1px solid rgba(255, 115, 0, 0.72);
            color: var(--icb-footer-orange);
            background: transparent;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            cursor: pointer;
            transition: background 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
        }

        .icb-footer-quickstart-button:hover {
            color: #000;
            background: var(--icb-footer-orange);
            box-shadow: 0 0 18px rgba(255, 115, 0, 0.35);
        }

        .icb-footer-quickstart-note {
            margin: 13px 0 0;
            color: var(--icb-footer-muted);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.86rem, 0.92vw, 0.94rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1.6;
        }

        .icb-footer-bottom {
            min-height: 62px;
            border-top: 1px solid rgba(255, 255, 255, 0.08);
            padding-top: clamp(28px, 3.5vh, 37px);
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 32px;
        }

        .icb-footer-copyright,
        .icb-footer-legal a {
            margin: 0;
            color: var(--icb-footer-muted);
            font-family: 'NeueHaasDisplay-Roman', sans-serif !important;
            font-size: clamp(0.86rem, 0.92vw, 0.94rem);
            font-weight: 400;
            letter-spacing: 0.2px;
            line-height: 1.6;
            text-decoration: none;
        }

        .icb-footer-legal {
            display: flex;
            align-items: center;
            gap: 30px;
        }

        .icb-footer-legal a {
            transition: color 0.24s ease;
        }

        .icb-footer-legal a:hover {
            color: var(--icb-footer-orange);
        }

        .icb-footer-legal-separator {
            width: 1px;
            height: 20px;
            background: rgba(255, 115, 0, 0.72);
        }

        @media (max-width: 1580px) {
            .icb-footer-top {
                grid-template-columns: minmax(220px, 1.25fr) repeat(4, minmax(0, 1fr));
                gap: clamp(24px, 3vw, 36px);
            }

            .icb-footer-mascot {
                left: clamp(16px, 3vw, 32px);
            }

            .icb-footer-mid {
                grid-template-columns: minmax(260px, 1fr) minmax(300px, 1.15fr) minmax(240px, 1fr);
                gap: clamp(28px, 3.5vw, 48px);
            }

            .icb-footer-quickstart-form {
                width: 100%;
            }
        }

        @media (max-width: 1279px) {
            .icb-reference-footer {
                padding-top: clamp(104px, calc(8vh + 40px), 122px);
            }

            .icb-footer-top {
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: clamp(36px, 4vh, 48px) clamp(24px, 3vw, 36px);
            }

            .icb-footer-brand {
                grid-column: 1 / -1;
                max-width: none;
                padding-bottom: clamp(20px, 3vh, 28px);
                border-bottom: 1px solid var(--icb-footer-line);
            }

            .icb-footer-column,
            .icb-footer-contact {
                padding-left: 0;
                border-left: none;
                padding-top: 0;
            }

            .icb-footer-mid {
                grid-template-columns: 1fr 1fr;
                gap: 46px;
                min-height: auto;
            }

            .icb-footer-quickstart {
                grid-column: 1 / -1;
                justify-self: stretch;
                width: 100%;
                max-width: none;
            }

            .icb-newsletter-form {
                width: 100%;
            }
        }

        @media (max-width: 767px) {
            .icb-reference-footer {
                padding: clamp(96px, calc(8vh + 40px), 104px) 0 clamp(8px, calc(4vh - 20px), 14px);
            }

            .icb-footer-top,
            .icb-footer-mid {
                grid-template-columns: 1fr;
            }

            .icb-footer-top {
                gap: clamp(28px, 4vh, 36px);
            }

            .icb-footer-brand {
                min-height: auto;
                padding-bottom: clamp(18px, 3vh, 24px);
            }

            .icb-footer-logo-img {
                width: min(100%, 132px);
            }

            .icb-footer-brand-rule {
                width: min(280px, 80vw);
            }

            .icb-footer-mascot {
                position: relative;
                left: auto;
                margin-top: 20px;
            }

            .icb-footer-strategy {
                max-width: 100%;
                width: 100%;
            }

            .icb-footer-tagline {
                white-space: normal;
                line-height: 1.7;
            }

            .icb-footer-heading {
                justify-content: space-between;
            }

            .icb-footer-heading::after {
                flex: 1 1 auto;
                max-width: 140px;
            }

            .icb-social-list {
                gap: 14px;
                flex-wrap: wrap;
            }

            .icb-footer-bottom {
                flex-direction: column;
                padding-top: 28px;
            }

            .icb-footer-legal {
                flex-wrap: wrap;
                gap: 18px;
            }
        }
    /* footer */
