/* =============================================================
   Carbon Trading Exchange Marketplace — Page Scoped Styles
   Scope: .ctm-page  (only loaded for this template)
   Palette: emerald / teal / lime gradient on dark backgrounds,
   TripleMinds red kept for primary CTAs.
   Animations: hero orbs, marquee, scroll-reveal, magnetic hover,
   gradient borders, pulsing nodes, animated connector line.
============================================================= */

.ctm-page {
    --ctm-emerald: #10b981;
    --ctm-emerald-2: #059669;
    --ctm-emerald-3: #047857;
    --ctm-teal: #14b8a6;
    --ctm-cyan: #06b6d4;
    --ctm-lime: #84cc16;
    --ctm-dark: #07140f;
    --ctm-dark-2: #0d1f17;
    --ctm-dark-3: #122b20;
    --ctm-red: #ec2024;
    --ctm-red-2: #ff5a3d;
    --ctm-grad: linear-gradient(95deg, #10b981 0%, #14b8a6 45%, #06b6d4 100%);
    --ctm-grad-soft: linear-gradient(95deg, rgba(16,185,129,.14), rgba(6,182,212,.14));
    --ctm-grad-warm: linear-gradient(95deg, #ec2024 0%, #ff7a3d 100%);
    color: #111;
}

/* ---------- shared utilities ---------- */
.ctm-page .ctm-grad {
    background: var(--ctm-grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.ctm-page .ctm-grad--light {
    background: linear-gradient(95deg, #4ade80 0%, #2dd4bf 50%, #38bdf8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}

.ctm-page .ctm-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #047857;
    background: linear-gradient(95deg, rgba(16,185,129,.12), rgba(6,182,212,.12));
    border: 1px solid rgba(16,185,129,.25);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: 12px;
    font-weight: 700;
    padding: 8px 16px;
    border-radius: 999px;
    margin-bottom: 18px;
}
.ctm-page .ctm-eyebrow--light {
    color: #d1fae5;
    background: rgba(255,255,255,.04);
    border-color: rgba(16,185,129,.3);
}

/* chip with pulsing dot */
.ctm-page .ctm-chip {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: #d1fae5;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(16,185,129,.35);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    text-transform: uppercase;
    letter-spacing: .18em;
    font-size: 12px;
    font-weight: 700;
    padding: 9px 18px;
    border-radius: 999px;
    margin-bottom: 22px;
}
.ctm-page .ctm-chip__dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #34d399;
    box-shadow: 0 0 0 4px rgba(52,211,153,.22);
    animation: ctmPulse 2s ease-in-out infinite;
}
@keyframes ctmPulse {
    0%,100% { box-shadow: 0 0 0 4px rgba(52,211,153,.22); }
    50%     { box-shadow: 0 0 0 9px rgba(52,211,153,0);   }
}

/* buttons */
.ctm-page .ctm-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border: 0;
    border-radius: 14px;
    padding: 14px 26px;
    font-weight: 600;
    font-size: 15px;
    line-height: 1;
    cursor: pointer;
    text-decoration: none;
    transition: transform .3s cubic-bezier(.2,.8,.2,1),
                box-shadow .3s ease,
                background .3s ease;
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-btn--primary {
    color: #fff;
    background: linear-gradient(95deg, var(--ctm-red) 0%, var(--ctm-red-2) 100%);
    box-shadow: 0 14px 32px -12px rgba(236,32,36,.6),
                inset 0 1px 0 rgba(255,255,255,.18);
}
.ctm-page .ctm-btn--primary::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
    transform: translateX(-120%);
    transition: transform .7s cubic-bezier(.2,.8,.2,1);
    z-index: -1;
}
.ctm-page .ctm-btn--primary:hover { transform: translateY(-3px); box-shadow: 0 22px 44px -14px rgba(236,32,36,.78); color: #fff; }
.ctm-page .ctm-btn--primary:hover::after { transform: translateX(120%); }
.ctm-page .ctm-btn--lg { padding: 17px 32px; font-size: 16px; }

.ctm-page .ctm-btn--ghost {
    color: #d1fae5;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(16,185,129,.3);
    padding: 13px 22px;
}
.ctm-page .ctm-btn--ghost:hover {
    background: rgba(16,185,129,.12);
    border-color: rgba(16,185,129,.55);
    color: #fff;
}
.ctm-page .ctm-btn--ghost svg { transition: transform .3s ease; }
.ctm-page .ctm-btn--ghost:hover svg { transform: translateY(3px); }

/* check icon */
.ctm-page .ctm-check {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
    flex-shrink: 0;
}

/* section heads */
.ctm-page .ctm-section-head { margin-bottom: 50px; }
.ctm-page .ctm-section-head--center { text-align: center; max-width: 820px; margin-left: auto; margin-right: auto; }
.ctm-page .ctm-section-head--split {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 60px;
    align-items: end;
    margin-bottom: 60px;
}
.ctm-page .ctm-section-head__title {
    font-size: clamp(28px, 3.6vw, 46px);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -.02em;
    color: #0b1612;
    margin: 0;
}
.ctm-page .ctm-section-head__title--light { color: #fff; }
.ctm-page .ctm-section-head__sub {
    margin-top: 16px;
    color: #434343;
    font-size: 17px;
    line-height: 1.7;
}
.ctm-page .ctm-section-head__col p {
    margin: 0;
    color: #434343;
    line-height: 1.7;
    font-size: 16px;
}

/* scroll reveal (controlled by JS toggling .is-visible) */
.ctm-page .ctm-reveal {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
    will-change: opacity, transform;
}
.ctm-page .ctm-reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* =============================================================
   HERO
============================================================= */
.ctm-page .ctm-hero {
    position: relative;
    overflow: hidden;
    padding: 130px 0 80px;
    background: radial-gradient(140% 90% at 100% 0%, #0d1f17 0%, #050b08 70%);
    color: #fff;
    isolation: isolate;
}
.ctm-page .ctm-hero__bg { position: absolute; inset: 0; z-index: -1; }

.ctm-page .ctm-hero__grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 80%);
    animation: ctmGridShift 32s linear infinite;
}
@keyframes ctmGridShift {
    0%   { background-position: 0 0, 0 0; }
    100% { background-position: 56px 56px, 56px 56px; }
}

.ctm-page .ctm-hero__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: .55;
    animation: ctmFloat 16s ease-in-out infinite;
}
.ctm-page .ctm-hero__orb--emerald {
    width: 560px; height: 560px;
    background: #10b981;
    top: -180px; left: -120px;
}
.ctm-page .ctm-hero__orb--teal {
    width: 520px; height: 520px;
    background: #06b6d4;
    bottom: -200px; right: -120px;
    animation-delay: -5s;
}
.ctm-page .ctm-hero__orb--lime {
    width: 340px; height: 340px;
    background: #84cc16;
    top: 30%; right: 25%;
    opacity: .25;
    animation-delay: -10s;
}
@keyframes ctmFloat {
    0%,100% { transform: translate(0,0) scale(1); }
    33%     { transform: translate(40px,-30px) scale(1.06); }
    66%     { transform: translate(-30px,30px) scale(.96); }
}

.ctm-page .ctm-hero__noise {
    position: absolute; inset: 0;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
    mix-blend-mode: overlay;
    opacity: .35;
    pointer-events: none;
}

.ctm-page .ctm-particles {
    position: absolute; inset: 0;
    pointer-events: none;
}
.ctm-page .ctm-particles span {
    position: absolute;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: radial-gradient(circle, #4ade80 0%, transparent 70%);
    opacity: 0;
    animation: ctmParticle 9s linear infinite;
}
.ctm-page .ctm-particles span:nth-child(1) { left: 8%;  animation-delay: 0s;   animation-duration: 11s; }
.ctm-page .ctm-particles span:nth-child(2) { left: 18%; animation-delay: 2s;   animation-duration: 13s; }
.ctm-page .ctm-particles span:nth-child(3) { left: 32%; animation-delay: 5s;   animation-duration: 10s; }
.ctm-page .ctm-particles span:nth-child(4) { left: 48%; animation-delay: 7s;   animation-duration: 14s; }
.ctm-page .ctm-particles span:nth-child(5) { left: 62%; animation-delay: 1s;   animation-duration: 12s; }
.ctm-page .ctm-particles span:nth-child(6) { left: 75%; animation-delay: 4s;   animation-duration: 9s;  }
.ctm-page .ctm-particles span:nth-child(7) { left: 86%; animation-delay: 6s;   animation-duration: 13s; }
.ctm-page .ctm-particles span:nth-child(8) { left: 94%; animation-delay: 3s;   animation-duration: 11s; }
@keyframes ctmParticle {
    0%   { transform: translateY(110vh) scale(.6); opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 1; }
    100% { transform: translateY(-10vh) scale(1.2); opacity: 0; }
}

.ctm-page .ctm-hero__title {
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1.05;
    letter-spacing: -.025em;
    font-weight: 900;
    color: #fff;
    margin: 0 0 22px;
}
.ctm-page .ctm-hero__title-grad {
    display: inline-block;
    background: linear-gradient(95deg, #4ade80 0%, #2dd4bf 50%, #38bdf8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.ctm-page .ctm-hero__lead {
    font-size: 17px;
    line-height: 1.7;
    color: #d1fae5;
    opacity: .82;
    max-width: 640px;
    margin: 0 0 30px;
}

.ctm-page .ctm-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-bottom: 50px;
}

.ctm-page .ctm-hero__stats {
    list-style: none;
    padding: 0; margin: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    padding-top: 28px;
    border-top: 1px solid rgba(255,255,255,.08);
}
.ctm-page .ctm-hero__stats li { display: flex; flex-direction: column; gap: 6px; }
.ctm-page .ctm-hero__stats strong {
    font-size: clamp(20px, 2.2vw, 28px);
    font-weight: 800;
    line-height: 1;
    color: #fff;
    letter-spacing: -.02em;
}
.ctm-page .ctm-hero__stats strong em { font-style: normal; opacity: .65; font-weight: 600; }
.ctm-page .ctm-hero__stats span {
    font-size: 13px;
    color: #a7f3d0;
    opacity: .65;
    letter-spacing: .03em;
}

/* hero visual — operator console + floating accents */
.ctm-page .ctm-hero__visual {
    position: relative;
    min-height: 560px;
    perspective: 1400px;
}

/* shared pill used by hero/map callouts */
.ctm-page .ctm-floatcard__pill {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(16,185,129,.18);
    color: #4ade80;
    border: 1px solid rgba(74,222,128,.35);
    padding: 4px 10px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .1em;
}
.ctm-page .ctm-floatcard__dot {
    width: 6px; height: 6px;
    background: #4ade80;
    border-radius: 50%;
    animation: ctmPulse 1.8s ease-in-out infinite;
}
.ctm-page .ctm-floatcard__id {
    font-size: 11px;
    color: rgba(255,255,255,.55);
    font-weight: 600;
}
.ctm-page .ctm-up { color: #4ade80; font-weight: 700; }

/* ====== CONSOLE  ====== */
.ctm-page .ctm-console {
    position: relative;
    width: 100%;
    max-width: 440px;
    margin: 0 auto;
    padding: 22px 22px 18px;
    border-radius: 22px;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.02) 100%),
        radial-gradient(140% 140% at 0% 0%, rgba(16,185,129,.20) 0%, rgba(6,182,212,.04) 60%);
    border: 1px solid rgba(16,185,129,.32);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    box-shadow:
        0 50px 90px -40px rgba(0,0,0,.75),
        0 0 0 1px rgba(255,255,255,.03) inset,
        0 0 60px rgba(16,185,129,.18);
    transform: rotate(-1deg);
    animation: ctmConsoleFloat 8s ease-in-out infinite;
    z-index: 2;
}
@keyframes ctmConsoleFloat {
    0%,100% { transform: translateY(0) rotate(-1deg); }
    50%     { transform: translateY(-10px) rotate(-1deg); }
}

.ctm-page .ctm-console__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 14px;
    margin-bottom: 14px;
    border-bottom: 1px solid rgba(255,255,255,.06);
}
.ctm-page .ctm-console__brand {
    display: flex; align-items: center; gap: 10px;
}
.ctm-page .ctm-console__avatar {
    width: 30px; height: 30px;
    border-radius: 9px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #052e1b;
    box-shadow: 0 6px 16px -6px rgba(16,185,129,.55);
}
.ctm-page .ctm-console__brand strong {
    display: block;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
}
.ctm-page .ctm-console__brand span {
    font-size: 10.5px;
    color: rgba(255,255,255,.5);
    letter-spacing: .08em;
    text-transform: uppercase;
}
.ctm-page .ctm-console__live {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(74,222,128,.16);
    border: 1px solid rgba(74,222,128,.35);
    color: #4ade80;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
}
.ctm-page .ctm-console__pulse {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 0 rgba(74,222,128,.6);
    animation: ctmPulseDot 1.6s ease-in-out infinite;
}
@keyframes ctmPulseDot {
    0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,.55); }
    50%      { box-shadow: 0 0 0 6px rgba(74,222,128,0); }
}

.ctm-page .ctm-console__hero {
    position: relative;
    padding: 14px 16px;
    border-radius: 14px;
    background:
        radial-gradient(120% 100% at 100% 0%, rgba(16,185,129,.18) 0%, transparent 60%),
        rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.06);
    overflow: hidden;
    margin-bottom: 12px;
}
.ctm-page .ctm-console__hero-label {
    font-size: 10px;
    letter-spacing: .14em;
    color: rgba(167,243,208,.65);
    text-transform: uppercase;
    font-weight: 700;
}
.ctm-page .ctm-console__hero-value {
    margin-top: 2px;
    display: flex;
    align-items: baseline;
    gap: 6px;
}
.ctm-page .ctm-console__hero-value strong {
    font-size: clamp(28px, 3.4vw, 38px);
    font-weight: 900;
    letter-spacing: -.025em;
    color: #fff;
    background: linear-gradient(95deg, #ffffff 0%, #4ade80 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
}
.ctm-page .ctm-console__hero-value small {
    font-size: 13px;
    font-weight: 600;
    color: rgba(255,255,255,.55);
}
.ctm-page .ctm-console__hero-meta {
    display: flex; align-items: center; gap: 8px;
    margin-top: 2px;
    font-size: 12px;
}
.ctm-page .ctm-console__delta {
    font-weight: 700;
    color: #4ade80;
}
.ctm-page .ctm-console__sub {
    color: rgba(255,255,255,.45);
}
.ctm-page .ctm-console__spark {
    position: absolute;
    inset: 12px 16px 12px auto;
    width: 50%;
    pointer-events: none;
    opacity: .9;
}
.ctm-page .ctm-console__spark svg { width: 100%; height: 100%; }
.ctm-page .ctm-console__spark-line {
    stroke-dasharray: 600;
    stroke-dashoffset: 600;
    animation: ctmSparkDraw 3.2s cubic-bezier(.2,.8,.2,1) .3s forwards;
}
@keyframes ctmSparkDraw {
    to { stroke-dashoffset: 0; }
}

.ctm-page .ctm-console__metrics {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-bottom: 14px;
}
.ctm-page .ctm-console__metrics > div {
    padding: 10px 8px;
    border-radius: 10px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.06);
    text-align: center;
    transition: background .3s ease, border-color .3s ease;
}
.ctm-page .ctm-console__metrics > div:hover {
    background: rgba(16,185,129,.08);
    border-color: rgba(74,222,128,.3);
}
.ctm-page .ctm-console__metrics strong {
    display: block;
    font-size: 16px;
    font-weight: 800;
    color: #fff;
    letter-spacing: -.01em;
}
.ctm-page .ctm-console__metrics span {
    font-size: 10.5px;
    color: rgba(255,255,255,.55);
    letter-spacing: .04em;
}

.ctm-page .ctm-console__feed {
    border-radius: 12px;
    background: rgba(0,0,0,.18);
    border: 1px solid rgba(255,255,255,.05);
    overflow: hidden;
}
.ctm-page .ctm-console__feed-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 14px;
    border-bottom: 1px solid rgba(255,255,255,.05);
    font-size: 10px;
    letter-spacing: .14em;
    color: rgba(167,243,208,.65);
    font-weight: 700;
}
.ctm-page .ctm-console__feed-track {
    height: 132px;
    overflow: hidden;
    position: relative;
    mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
    -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 18%, #000 82%, transparent 100%);
}
.ctm-page .ctm-console__feed-track {
    animation: ctmFeedScroll 16s linear infinite;
}
@keyframes ctmFeedScroll {
    0%   { transform: translateY(0); }
    100% { transform: translateY(-50%); }
}
.ctm-page .ctm-console__trade {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 11px 14px;
    border-bottom: 1px dashed rgba(255,255,255,.06);
}
.ctm-page .ctm-console__trade-info strong {
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: #fff;
}
.ctm-page .ctm-console__trade-info span {
    font-size: 10.5px;
    color: rgba(255,255,255,.5);
    letter-spacing: .02em;
}
.ctm-page .ctm-console__trade-amt {
    text-align: right;
}
.ctm-page .ctm-console__trade-amt strong {
    display: block;
    font-size: 13px;
    font-weight: 800;
    color: #4ade80;
    letter-spacing: -.01em;
}
.ctm-page .ctm-console__trade-amt span {
    font-size: 10.5px;
    color: rgba(255,255,255,.5);
}

/* ====== FLOATING ACCENTS ====== */
.ctm-page .ctm-hbadge {
    position: absolute;
    z-index: 3;
    padding: 12px 14px;
    border-radius: 14px;
    color: #fff;
    background:
        linear-gradient(135deg, rgba(255,255,255,.08) 0%, rgba(255,255,255,.02) 100%),
        radial-gradient(140% 140% at 0% 0%, rgba(16,185,129,.18) 0%, rgba(6,182,212,.04) 60%);
    border: 1px solid rgba(16,185,129,.3);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 24px 50px -22px rgba(0,0,0,.7);
    animation: ctmHbadgeFloat 9s ease-in-out infinite;
}
@keyframes ctmHbadgeFloat {
    0%,100% { transform: translateY(0) rotate(var(--rot, 0deg)); }
    50%     { transform: translateY(-8px) rotate(var(--rot, 0deg)); }
}

/* registries — top right */
.ctm-page .ctm-hbadge--reg {
    --rot: 3deg;
    top: -10px; right: -16px;
    padding: 12px 14px 10px;
    width: 188px;
    animation-delay: -1s;
}
.ctm-page .ctm-hbadge__label {
    display: block;
    font-size: 9.5px;
    letter-spacing: .18em;
    color: rgba(167,243,208,.65);
    font-weight: 700;
    margin-bottom: 8px;
}
.ctm-page .ctm-hbadge__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}
.ctm-page .ctm-hbadge__chips span {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .06em;
    padding: 4px 9px;
    border-radius: 999px;
    background: rgba(74,222,128,.14);
    border: 1px solid rgba(74,222,128,.3);
    color: #4ade80;
}

/* NFT cert — bottom left */
.ctm-page .ctm-hbadge--cert {
    --rot: -3deg;
    left: -10px;
    bottom: 90px;
    display: flex;
    align-items: center;
    gap: 10px;
    width: 240px;
    animation-delay: -3.5s;
}
.ctm-page .ctm-hbadge__icon {
    flex-shrink: 0;
    width: 34px; height: 34px;
    border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
    box-shadow: 0 8px 20px -8px rgba(16,185,129,.5);
}
.ctm-page .ctm-hbadge--cert strong {
    display: block;
    font-size: 12.5px;
    font-weight: 700;
    color: #fff;
    line-height: 1.25;
}
.ctm-page .ctm-hbadge--cert span {
    font-size: 10.5px;
    color: rgba(209,250,229,.7);
}

/* tokenization chip — bottom right */
.ctm-page .ctm-hbadge--chain {
    --rot: 2deg;
    right: -8px;
    bottom: 6px;
    display: flex;
    align-items: center;
    gap: 10px;
    width: 220px;
    animation-delay: -5s;
}
.ctm-page .ctm-hbadge__chain-orb {
    flex-shrink: 0;
    width: 30px; height: 30px;
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 35%, #4ade80 0%, #06b6d4 60%, #052e1b 100%);
    box-shadow:
        0 0 0 2px rgba(74,222,128,.25),
        0 0 18px rgba(74,222,128,.45);
    animation: ctmOrbSpin 6s linear infinite;
}
@keyframes ctmOrbSpin {
    0%   { background-position: 0 0; transform: rotate(0); }
    100% { background-position: 0 0; transform: rotate(360deg); }
}
.ctm-page .ctm-hbadge--chain strong {
    display: block;
    font-size: 12.5px;
    font-weight: 700;
    color: #fff;
    line-height: 1.25;
}
.ctm-page .ctm-hbadge--chain span {
    font-size: 10.5px;
    color: rgba(209,250,229,.7);
}

.ctm-page .ctm-hero__leaf {
    position: absolute;
    width: 100px; height: 100px;
    bottom: 30px; left: 50px;
    color: rgba(74,222,128,.18);
    animation: ctmSpin 22s linear infinite;
    pointer-events: none;
}
@keyframes ctmSpin {
    to { transform: rotate(360deg); }
}

/* hero marquee */
.ctm-page .ctm-hero__marquee {
    margin-top: 70px;
    overflow: hidden;
    mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
    -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.ctm-page .ctm-marquee__track {
    display: flex;
    gap: 60px;
    width: max-content;
    animation: ctmMarquee 32s linear infinite;
}
.ctm-page .ctm-marquee__track span {
    font-size: 13px;
    letter-spacing: .28em;
    font-weight: 700;
    color: rgba(167,243,208,.32);
    white-space: nowrap;
}
@keyframes ctmMarquee {
    from { transform: translateX(0); }
    to   { transform: translateX(-50%); }
}


/* =============================================================
   WHAT IS / HOW IT WORKS
============================================================= */
.ctm-page .ctm-what {
    padding: 110px 0;
    background: #fff;
    position: relative;
}
.ctm-page .ctm-what__visual {
    position: relative;
    padding: 30px;
}
.ctm-page .ctm-what__blob {
    position: absolute;
    inset: 0;
    background: radial-gradient(50% 50% at 30% 30%, rgba(16,185,129,.25) 0%, transparent 60%),
                radial-gradient(60% 50% at 80% 70%, rgba(6,182,212,.22) 0%, transparent 60%);
    border-radius: 60% 40% 50% 60% / 50% 60% 40% 50%;
    animation: ctmMorph 12s ease-in-out infinite;
    z-index: 0;
}
@keyframes ctmMorph {
    0%,100% { border-radius: 60% 40% 50% 60% / 50% 60% 40% 50%; }
    50%     { border-radius: 40% 60% 60% 40% / 60% 40% 50% 50%; }
}
.ctm-page .ctm-what__frame {
    position: relative;
    z-index: 1;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(135deg, #d1fae5, #cffafe);
    padding: 8px;
    box-shadow: 0 30px 60px -25px rgba(16,185,129,.35);
}
.ctm-page .ctm-what__frame img {
    border-radius: 18px;
    display: block;
    width: 100%;
    transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-what__visual:hover .ctm-what__frame img { transform: scale(1.04); }
.ctm-page .ctm-what__badge {
    position: absolute;
    bottom: 18px;
    right: -10px;
    display: flex;
    align-items: center;
    gap: 12px;
    background: #fff;
    padding: 14px 18px;
    border-radius: 16px;
    box-shadow: 0 22px 44px -20px rgba(7,20,15,.3),
                0 4px 14px -6px rgba(7,20,15,.12);
    z-index: 2;
    animation: ctmCardFloat 6s ease-in-out infinite;
    --rot: 0deg;
}
.ctm-page .ctm-what__badge-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px; height: 42px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
}
.ctm-page .ctm-what__badge b {
    display: block;
    font-size: 14px;
    color: #0b1612;
    font-weight: 700;
    line-height: 1.2;
}
.ctm-page .ctm-what__badge span {
    font-size: 12px;
    color: #6b7280;
    letter-spacing: .05em;
}

.ctm-page .ctm-what__content p {
    color: #434343;
    font-size: 16px;
    line-height: 1.85;
    margin-bottom: 16px;
}
.ctm-page .ctm-what__content p:last-child { margin-bottom: 0; }

.ctm-page .ctm-what__stats {
    list-style: none;
    padding: 24px 0 0; margin: 22px 0 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px 24px;
    border-top: 1px solid rgba(16,185,129,.16);
}
.ctm-page .ctm-what__stats li { display: flex; flex-direction: column; gap: 4px; }
.ctm-page .ctm-what__stats strong {
    font-size: 15px;
    font-weight: 700;
    color: #0b1612;
    letter-spacing: -.01em;
}
.ctm-page .ctm-what__stats span {
    font-size: 12px;
    color: #6b7280;
    letter-spacing: .05em;
    text-transform: uppercase;
    font-weight: 600;
}


/* =============================================================
   ROLES
============================================================= */
.ctm-page .ctm-roles {
    padding: 110px 0;
    background: linear-gradient(180deg, #fff 0%, #f0fdf4 100%);
}
.ctm-page .ctm-role-card {
    position: relative;
    height: 100%;
    padding: 36px 30px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(16,185,129,.12);
    overflow: hidden;
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                box-shadow .5s ease,
                border-color .5s ease;
    isolation: isolate;
}
.ctm-page .ctm-role-card::before {
    content: "";
    position: absolute;
    inset: 0;
    padding: 1px;
    background: var(--ctm-grad);
    border-radius: inherit;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
            mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    opacity: 0;
    transition: opacity .5s ease;
    pointer-events: none;
}
.ctm-page .ctm-role-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px -30px rgba(16,185,129,.35);
    border-color: transparent;
}
.ctm-page .ctm-role-card:hover::before { opacity: 1; }
.ctm-page .ctm-role-card:hover .ctm-role-card__num {
    background: var(--ctm-grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    opacity: .8;
}
.ctm-page .ctm-role-card__num {
    font-size: 64px;
    font-weight: 900;
    line-height: 1;
    color: rgba(16,185,129,.18);
    letter-spacing: -.04em;
    margin-bottom: 28px;
    transition: opacity .4s ease;
}
.ctm-page .ctm-role-card__icon {
    width: 56px; height: 56px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(16,185,129,.15), rgba(6,182,212,.15));
    color: var(--ctm-emerald-3);
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 22px;
    transition: transform .4s ease;
}
.ctm-page .ctm-role-card:hover .ctm-role-card__icon { transform: scale(1.08) rotate(-4deg); }
.ctm-page .ctm-role-card h3 {
    font-size: 22px;
    font-weight: 700;
    line-height: 1.3;
    color: #0b1612;
    margin: 0 0 14px;
}
.ctm-page .ctm-role-card p {
    color: #434343;
    font-size: 15px;
    line-height: 1.75;
    margin: 0;
}
.ctm-page .ctm-role-card__glow {
    position: absolute;
    width: 260px; height: 260px;
    background: radial-gradient(circle, rgba(16,185,129,.18) 0%, transparent 70%);
    border-radius: 50%;
    right: -100px;
    bottom: -100px;
    transition: transform .6s cubic-bezier(.2,.8,.2,1);
    z-index: -1;
}
.ctm-page .ctm-role-card:hover .ctm-role-card__glow { transform: scale(1.5); }


/* =============================================================
   LIFECYCLE
============================================================= */
.ctm-page .ctm-lifecycle {
    position: relative;
    padding: 120px 0;
    background: radial-gradient(120% 80% at 50% 0%, #0d1f17 0%, #050b08 70%);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-lifecycle__bg { position: absolute; inset: 0; z-index: -1; }
.ctm-page .ctm-lifecycle__grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 80%);
}
.ctm-page .ctm-lifecycle__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: .35;
    animation: ctmFloat 14s ease-in-out infinite;
}
.ctm-page .ctm-lifecycle__orb--a {
    width: 520px; height: 520px;
    background: #10b981;
    top: -180px; left: 5%;
}
.ctm-page .ctm-lifecycle__orb--b {
    width: 460px; height: 460px;
    background: #06b6d4;
    bottom: -160px; right: 5%;
    animation-delay: -7s;
}

.ctm-page .ctm-life {
    position: relative;
    padding-top: 40px;
}
.ctm-page .ctm-life__line {
    position: absolute;
    top: 80px;
    left: 6%;
    right: 6%;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(74,222,128,.35) 12%, rgba(45,212,191,.35) 50%, rgba(56,189,248,.35) 88%, transparent);
    border-radius: 999px;
    pointer-events: none;
    overflow: hidden;
}
.ctm-page .ctm-life__line-glow {
    position: absolute;
    top: 0; left: -20%;
    width: 20%; height: 100%;
    background: linear-gradient(90deg, transparent, rgba(74,222,128,1), transparent);
    filter: blur(2px);
    animation: ctmLineShine 4.5s linear infinite;
}
@keyframes ctmLineShine {
    0%   { left: -20%; }
    100% { left: 120%; }
}

.ctm-page .ctm-life__steps {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 24px;
    position: relative;
    z-index: 1;
}
.ctm-page .ctm-life__steps--six { grid-template-columns: repeat(6, 1fr); gap: 18px; }
.ctm-page .ctm-life__step {
    text-align: center;
    padding: 0 6px;
    position: relative;
}
.ctm-page .ctm-life__node {
    width: 56px; height: 56px;
    margin: 0 auto 20px;
    border-radius: 50%;
    background: linear-gradient(135deg, #052e1b, #0a4a3a);
    border: 2px solid rgba(74,222,128,.6);
    color: #4ade80;
    display: flex; align-items: center; justify-content: center;
    font-weight: 800;
    font-size: 18px;
    position: relative;
    box-shadow: 0 0 0 6px rgba(7,20,15,1),
                0 0 24px rgba(74,222,128,.45);
    transition: transform .4s ease, box-shadow .4s ease;
}
.ctm-page .ctm-life__node::before {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 1px solid rgba(74,222,128,.3);
    animation: ctmRipple 2.8s ease-out infinite;
}
.ctm-page .ctm-life__node::after {
    content: "";
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 1px solid rgba(74,222,128,.3);
    animation: ctmRipple 2.8s ease-out infinite;
    animation-delay: 1.4s;
}
@keyframes ctmRipple {
    0%   { transform: scale(1);   opacity: .7; }
    100% { transform: scale(1.9); opacity: 0;  }
}
.ctm-page .ctm-life__step:hover .ctm-life__node {
    transform: scale(1.1);
    box-shadow: 0 0 0 6px rgba(7,20,15,1),
                0 0 32px rgba(74,222,128,.75);
}

.ctm-page .ctm-life__icon {
    width: 70px; height: 70px;
    margin: 0 auto 18px;
    border-radius: 18px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(16,185,129,.25);
    display: flex; align-items: center; justify-content: center;
    padding: 14px;
    transition: transform .4s ease, background .4s ease;
}
.ctm-page .ctm-life__icon img {
    max-width: 100%; max-height: 100%;
    filter: brightness(0) saturate(100%) invert(86%) sepia(33%) saturate(580%) hue-rotate(82deg) brightness(96%) contrast(90%);
}
.ctm-page .ctm-life__step:hover .ctm-life__icon {
    background: rgba(16,185,129,.15);
    transform: translateY(-4px);
}

.ctm-page .ctm-life__step h3 {
    font-size: 18px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 10px;
}
.ctm-page .ctm-life__step p {
    font-size: 13.5px;
    line-height: 1.7;
    color: rgba(209,250,229,.7);
    margin: 0;
}


/* =============================================================
   FEATURES
============================================================= */
.ctm-page .ctm-features {
    padding: 120px 0;
    background: #fff;
    position: relative;
}
.ctm-page .ctm-features__grid { margin-top: 10px; }

.ctm-page .ctm-feature-card {
    position: relative;
    height: 100%;
    padding: 2px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(16,185,129,.12), rgba(6,182,212,.06));
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                box-shadow .5s ease;
    isolation: isolate;
}
.ctm-page .ctm-feature-card__border {
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: 1.5px;
    background: var(--ctm-grad);
    opacity: 0;
    transition: opacity .5s ease;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
            mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
}
.ctm-page .ctm-feature-card__inner {
    position: relative;
    height: 100%;
    padding: 30px 26px;
    border-radius: 20px;
    background: #fff;
    overflow: hidden;
}
.ctm-page .ctm-feature-card__inner::before {
    content: "";
    position: absolute;
    top: 0; left: 50%;
    width: 200%; height: 200%;
    background: radial-gradient(circle, rgba(16,185,129,.18) 0%, transparent 60%);
    transform: translate(-50%, -100%);
    transition: transform .6s cubic-bezier(.2,.8,.2,1);
    pointer-events: none;
}
.ctm-page .ctm-feature-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px -30px rgba(16,185,129,.4);
}
.ctm-page .ctm-feature-card:hover .ctm-feature-card__border { opacity: 1; }
.ctm-page .ctm-feature-card:hover .ctm-feature-card__inner::before {
    transform: translate(-50%, -55%);
}
.ctm-page .ctm-feature-card__icon {
    width: 64px; height: 64px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(16,185,129,.14), rgba(6,182,212,.14));
    display: flex; align-items: center; justify-content: center;
    padding: 14px;
    margin-bottom: 22px;
    position: relative;
    z-index: 1;
    transition: transform .4s ease;
}
.ctm-page .ctm-feature-card:hover .ctm-feature-card__icon {
    transform: scale(1.06) rotate(-6deg);
}
.ctm-page .ctm-feature-card__icon img {
    max-width: 100%; max-height: 100%;
}
.ctm-page .ctm-feature-card h3 {
    position: relative;
    z-index: 1;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.35;
    color: #0b1612;
    margin: 0 0 12px;
    min-height: 48px;
}
.ctm-page .ctm-feature-card p {
    position: relative;
    z-index: 1;
    font-size: 14px;
    line-height: 1.7;
    color: #515564;
    margin: 0;
}
.ctm-page .ctm-feature-card__arrow {
    position: absolute;
    top: 26px; right: 26px;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(16,185,129,.1);
    color: var(--ctm-emerald-3);
    display: inline-flex; align-items: center; justify-content: center;
    opacity: 0;
    transform: translate(-6px, 6px);
    transition: opacity .4s ease, transform .4s ease, background .4s ease;
    z-index: 1;
}
.ctm-page .ctm-feature-card:hover .ctm-feature-card__arrow {
    opacity: 1;
    transform: translate(0, 0);
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
}


/* =============================================================
   CTA
============================================================= */
.ctm-page .ctm-cta { padding: 30px 0 80px; }
.ctm-page .ctm-cta--dark { padding: 80px 0; }

.ctm-page .ctm-cta__card {
    position: relative;
    padding: 80px 50px;
    border-radius: 32px;
    background: linear-gradient(135deg, #f0fdf4 0%, #ecfeff 100%);
    border: 1px solid rgba(16,185,129,.2);
    overflow: hidden;
    isolation: isolate;
    text-align: center;
}
.ctm-page .ctm-cta__card--dark {
    background: radial-gradient(120% 100% at 50% 0%, #0d1f17 0%, #050b08 100%);
    border-color: rgba(16,185,129,.25);
    color: #fff;
}
.ctm-page .ctm-cta__bg {
    position: absolute; inset: 0; z-index: -1;
    pointer-events: none;
    overflow: hidden;
}
.ctm-page .ctm-cta__shape {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: .5;
    animation: ctmFloat 12s ease-in-out infinite;
}
.ctm-page .ctm-cta__shape--a {
    width: 380px; height: 380px;
    background: #10b981;
    top: -160px; left: -80px;
}
.ctm-page .ctm-cta__shape--b {
    width: 320px; height: 320px;
    background: #06b6d4;
    bottom: -160px; right: -80px;
    animation-delay: -5s;
}
.ctm-page .ctm-cta__shape--c {
    width: 240px; height: 240px;
    background: #84cc16;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    opacity: .15;
    animation-delay: -3s;
}
.ctm-page .ctm-cta__card--dark .ctm-cta__shape { opacity: .35; }

.ctm-page .ctm-cta__inner {
    position: relative;
    z-index: 1;
    max-width: 760px;
    margin: 0 auto;
}
.ctm-page .ctm-cta__card h2 {
    font-size: clamp(28px, 3.4vw, 44px);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -.02em;
    color: #0b1612;
    margin: 0 0 18px;
}
.ctm-page .ctm-cta__card--dark h2 { color: #fff; }
.ctm-page .ctm-cta__card p {
    font-size: 17px;
    line-height: 1.7;
    color: #434343;
    margin: 0 0 32px;
}
.ctm-page .ctm-cta__card--dark p { color: rgba(209,250,229,.78); }


/* =============================================================
   COMPLIANCE
============================================================= */
.ctm-page .ctm-compliance {
    padding: 120px 0;
    background: linear-gradient(180deg, #ffffff 0%, #f0fdf4 100%);
}
.ctm-page .ctm-compliance-card {
    height: 100%;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(16,185,129,.12);
    overflow: hidden;
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                box-shadow .5s ease;
}
.ctm-page .ctm-compliance-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px -30px rgba(16,185,129,.35);
}
.ctm-page .ctm-compliance-card__image {
    position: relative;
    aspect-ratio: 16 / 9;
    overflow: hidden;
}
.ctm-page .ctm-compliance-card__image img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .7s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-compliance-card:hover .ctm-compliance-card__image img {
    transform: scale(1.07);
}
.ctm-page .ctm-compliance-card__image-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(0deg, rgba(13,31,23,.55) 0%, transparent 50%);
    pointer-events: none;
}
.ctm-page .ctm-compliance-card__body {
    padding: 30px 28px;
}
.ctm-page .ctm-compliance-card__body h3 {
    font-size: 20px;
    font-weight: 700;
    color: #0b1612;
    margin: 0 0 18px;
    line-height: 1.35;
}
.ctm-page .ctm-compliance-card__body ul {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.ctm-page .ctm-compliance-card__body li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: #434343;
    font-size: 15px;
    line-height: 1.6;
}


/* =============================================================
   ADMIN
============================================================= */
.ctm-page .ctm-admin {
    position: relative;
    padding: 130px 0;
    background: radial-gradient(120% 80% at 50% 0%, #0d1f17 0%, #050b08 80%);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-admin__bg { position: absolute; inset: 0; z-index: -1; }
.ctm-page .ctm-admin__grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 85%);
    -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, #000 30%, transparent 85%);
}
.ctm-page .ctm-admin__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: .35;
    animation: ctmFloat 18s ease-in-out infinite;
}
.ctm-page .ctm-admin__orb--a {
    width: 500px; height: 500px;
    background: #06b6d4;
    top: -180px; right: -100px;
}
.ctm-page .ctm-admin__orb--b {
    width: 460px; height: 460px;
    background: #10b981;
    bottom: -180px; left: -100px;
    animation-delay: -6s;
}

.ctm-page .ctm-admin__title {
    font-size: clamp(26px, 3.4vw, 44px);
    font-weight: 800;
    line-height: 1.2;
    letter-spacing: -.02em;
    color: #fff;
    margin: 0 0 28px;
}
.ctm-page .ctm-admin__title--sm {
    font-size: clamp(24px, 2.6vw, 36px);
    margin-bottom: 16px;
}
.ctm-page .ctm-admin__sub {
    font-size: 16px;
    line-height: 1.7;
    color: rgba(209,250,229,.7);
    max-width: 760px;
}

.ctm-page .ctm-admin__top { margin-bottom: 50px; }
.ctm-page .ctm-admin__list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ctm-page .ctm-admin__row {
    padding: 24px 26px;
    border-radius: 16px;
    background: rgba(255,255,255,.02);
    border: 1px solid rgba(255,255,255,.06);
    transition: background .4s ease, border-color .4s ease, transform .4s ease;
    position: relative;
    overflow: hidden;
}
.ctm-page .ctm-admin__row::before {
    content: "";
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    background: var(--ctm-grad);
    transform: scaleY(0);
    transform-origin: top;
    transition: transform .4s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-admin__row:hover {
    background: rgba(16,185,129,.05);
    border-color: rgba(16,185,129,.25);
    transform: translateX(6px);
}
.ctm-page .ctm-admin__row:hover::before { transform: scaleY(1); }
.ctm-page .ctm-admin__row h3 {
    font-size: 19px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 8px;
}
.ctm-page .ctm-admin__row p {
    font-size: 15px;
    line-height: 1.7;
    color: rgba(209,250,229,.65);
    margin: 0;
}

.ctm-page .ctm-admin__divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
    margin: 70px 0;
}

.ctm-page .ctm-admin__deck { margin-top: 40px; }

.ctm-page .ctm-verify-card {
    position: relative;
    height: 100%;
    padding: 36px 32px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255,255,255,.04) 0%, rgba(255,255,255,.01) 100%);
    border: 1px solid rgba(255,255,255,.08);
    overflow: hidden;
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                border-color .5s ease,
                background .5s ease;
}
.ctm-page .ctm-verify-card:hover {
    transform: translateY(-6px);
    border-color: rgba(16,185,129,.4);
    background: linear-gradient(180deg, rgba(16,185,129,.08) 0%, rgba(6,182,212,.02) 100%);
}
.ctm-page .ctm-verify-card::before {
    content: "";
    position: absolute;
    top: -1px; left: -1px; right: -1px;
    height: 2px;
    background: var(--ctm-grad);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .6s cubic-bezier(.2,.8,.2,1);
    border-radius: 22px 22px 0 0;
}
.ctm-page .ctm-verify-card:hover::before { transform: scaleX(1); }
.ctm-page .ctm-verify-card__num {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .2em;
    color: #4ade80;
    margin-bottom: 14px;
}
.ctm-page .ctm-verify-card h3 {
    font-size: 21px;
    font-weight: 700;
    color: #fff;
    margin: 0 0 22px;
    line-height: 1.3;
}
.ctm-page .ctm-verify-card ul {
    list-style: none;
    padding: 0; margin: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.ctm-page .ctm-verify-card li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: rgba(209,250,229,.7);
    font-size: 15px;
    line-height: 1.6;
}
.ctm-page .ctm-bullet {
    width: 8px; height: 8px;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 8px;
    box-shadow: 0 0 0 3px rgba(16,185,129,.12);
}


/* =============================================================
   MONETIZE
============================================================= */
.ctm-page .ctm-monetize {
    padding: 120px 0;
    background: #fff;
}
.ctm-page .ctm-money-card {
    position: relative;
    height: 100%;
    padding: 32px 26px 60px;
    border-radius: 22px;
    background: #fff;
    border: 1px solid rgba(16,185,129,.14);
    overflow: hidden;
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                box-shadow .5s ease,
                border-color .5s ease;
}
.ctm-page .ctm-money-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px -30px rgba(16,185,129,.35);
    border-color: transparent;
}
.ctm-page .ctm-money-card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(16,185,129,.05) 0%, transparent 40%);
    opacity: 0;
    transition: opacity .5s ease;
    pointer-events: none;
}
.ctm-page .ctm-money-card:hover::before { opacity: 1; }
.ctm-page .ctm-money-card__icon {
    width: 60px; height: 60px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(16,185,129,.14), rgba(6,182,212,.14));
    display: flex; align-items: center; justify-content: center;
    padding: 12px;
    margin-bottom: 22px;
    transition: transform .4s ease;
}
.ctm-page .ctm-money-card:hover .ctm-money-card__icon {
    transform: scale(1.08) rotate(-5deg);
}
.ctm-page .ctm-money-card__icon img { max-width: 100%; max-height: 100%; }
.ctm-page .ctm-money-card h3 {
    font-size: 19px;
    font-weight: 700;
    color: #0b1612;
    margin: 0 0 12px;
    line-height: 1.3;
    min-height: 50px;
}
.ctm-page .ctm-money-card p {
    font-size: 14.5px;
    line-height: 1.7;
    color: #515564;
    margin: 0;
}
.ctm-page .ctm-money-card__tag {
    position: absolute;
    bottom: 18px; right: 18px;
    padding: 6px 12px;
    background: linear-gradient(95deg, rgba(16,185,129,.12), rgba(6,182,212,.12));
    color: var(--ctm-emerald-3);
    border: 1px solid rgba(16,185,129,.22);
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
}


/* =============================================================
   PROTOTYPE
============================================================= */
.ctm-page .ctm-proto {
    padding: 120px 0;
    background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
}
.ctm-page .ctm-proto__visual {
    position: relative;
}
.ctm-page .ctm-proto__price {
    position: absolute;
    top: -30px; left: -10px;
    z-index: 2;
    padding: 22px 28px;
    background: linear-gradient(135deg, var(--ctm-emerald) 0%, var(--ctm-cyan) 100%);
    color: #fff;
    border-radius: 20px;
    box-shadow: 0 26px 50px -20px rgba(16,185,129,.55);
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-proto__price::before {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
    transform: translateX(-100%);
    animation: ctmShimmer 3s ease-in-out infinite;
    z-index: -1;
}
@keyframes ctmShimmer {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(100%); }
}
.ctm-page .ctm-proto__price-from {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .18em;
    opacity: .85;
    margin-bottom: 4px;
}
.ctm-page .ctm-proto__price strong {
    display: block;
    font-size: 42px;
    font-weight: 900;
    line-height: 1;
    letter-spacing: -.02em;
}
.ctm-page .ctm-proto__price strong small {
    font-size: 14px;
    font-weight: 600;
    opacity: .85;
    margin-left: 6px;
    letter-spacing: .1em;
}
.ctm-page .ctm-proto__price-foot {
    display: block;
    font-size: 13px;
    margin-top: 6px;
    opacity: .9;
}

.ctm-page .ctm-proto__frame {
    position: relative;
    border-radius: 26px;
    overflow: hidden;
    padding: 10px;
    background: linear-gradient(135deg, #d1fae5, #cffafe);
    box-shadow: 0 30px 60px -25px rgba(16,185,129,.35);
}
.ctm-page .ctm-proto__frame img {
    width: 100%;
    display: block;
    border-radius: 18px;
    transition: transform .8s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-proto__visual:hover .ctm-proto__frame img { transform: scale(1.03); }

.ctm-page .ctm-proto__lead {
    font-size: 16px;
    line-height: 1.8;
    color: #434343;
    margin: 18px 0 0;
}
.ctm-page .ctm-proto__sub {
    font-size: 20px;
    font-weight: 700;
    color: #0b1612;
    margin: 28px 0 18px;
}
.ctm-page .ctm-proto__list {
    list-style: none;
    padding: 0; margin: 0 0 24px;
    display: flex; flex-direction: column;
    gap: 14px;
}
.ctm-page .ctm-proto__list li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-size: 15px;
    line-height: 1.6;
    color: #434343;
}
.ctm-page .ctm-proto__note {
    font-style: italic;
    font-size: 15px;
    line-height: 1.7;
    color: #047857;
    padding: 14px 18px;
    background: linear-gradient(95deg, rgba(16,185,129,.08), rgba(6,182,212,.08));
    border-left: 3px solid var(--ctm-emerald);
    border-radius: 0 10px 10px 0;
    margin: 0;
}


/* =============================================================
   ARCHITECTURE
============================================================= */
.ctm-page .ctm-arch {
    padding: 120px 0;
    background: #fff;
}
.ctm-page .ctm-arch__lead {
    font-size: 16px;
    line-height: 1.8;
    color: #434343;
    margin: 18px 0 0;
}
.ctm-page .ctm-arch__list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.ctm-page .ctm-arch__item {
    display: flex;
    gap: 18px;
    padding: 22px 26px;
    border-radius: 16px;
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    transition: transform .4s ease, border-color .4s ease, box-shadow .4s ease;
}
.ctm-page .ctm-arch__item:hover {
    transform: translateX(6px);
    border-color: rgba(16,185,129,.3);
    box-shadow: 0 18px 36px -20px rgba(16,185,129,.25);
}
.ctm-page .ctm-arch__dot {
    flex-shrink: 0;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--dot, #34c759);
    margin-top: 6px;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--dot, #34c759) 18%, transparent);
    position: relative;
    animation: ctmDotPulse 2.4s ease-in-out infinite;
}
@keyframes ctmDotPulse {
    0%,100% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--dot, #34c759) 18%, transparent); }
    50%     { box-shadow: 0 0 0 8px color-mix(in srgb, var(--dot, #34c759) 0%,  transparent); }
}
.ctm-page .ctm-arch__item h3 {
    font-size: 19px;
    font-weight: 700;
    color: #0b1612;
    margin: 0 0 6px;
}
.ctm-page .ctm-arch__item p {
    font-size: 15px;
    line-height: 1.7;
    color: #434343;
    margin: 0;
}


/* =============================================================
   ENGAGEMENT MODELS
============================================================= */
.ctm-page .ctm-engage {
    padding: 120px 0;
    background: linear-gradient(180deg, #ffffff 0%, #f0fdf4 100%);
}
.ctm-page .ctm-engage__grid { margin-top: 10px; }
.ctm-page .ctm-engage-card {
    position: relative;
    height: 100%;
    padding: 36px 30px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    transition: transform .5s cubic-bezier(.2,.8,.2,1),
                box-shadow .5s ease,
                border-color .5s ease;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-engage-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 30px 60px -30px rgba(16,185,129,.3);
    border-color: rgba(16,185,129,.4);
}
.ctm-page .ctm-engage-card--featured {
    background: linear-gradient(180deg, #052e1b 0%, #0a4a3a 100%);
    border-color: transparent;
    color: #fff;
    transform: translateY(-12px);
    box-shadow: 0 30px 60px -25px rgba(16,185,129,.4);
}
.ctm-page .ctm-engage-card--featured:hover {
    transform: translateY(-18px);
    box-shadow: 0 40px 70px -25px rgba(16,185,129,.55);
}
.ctm-page .ctm-engage-card__star {
    position: absolute;
    top: 16px; right: 16px;
    background: linear-gradient(95deg, var(--ctm-red), var(--ctm-red-2));
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    padding: 6px 12px;
    border-radius: 999px;
    box-shadow: 0 8px 18px -6px rgba(236,32,36,.55);
}
.ctm-page .ctm-engage-card__head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 16px;
}
.ctm-page .ctm-engage-card__model {
    font-size: 13px;
    font-weight: 700;
    color: var(--ctm-emerald-2);
    letter-spacing: .14em;
    text-transform: uppercase;
}
.ctm-page .ctm-engage-card--featured .ctm-engage-card__model { color: #4ade80; }
.ctm-page .ctm-engage-card__num {
    font-size: 38px;
    font-weight: 900;
    color: rgba(16,185,129,.18);
    line-height: 1;
    letter-spacing: -.04em;
}
.ctm-page .ctm-engage-card--featured .ctm-engage-card__num { color: rgba(255,255,255,.15); }
.ctm-page .ctm-engage-card h3 {
    font-size: 23px;
    font-weight: 800;
    color: #0b1612;
    margin: 0 0 14px;
    letter-spacing: -.01em;
}
.ctm-page .ctm-engage-card--featured h3 { color: #fff; }
.ctm-page .ctm-engage-card__rate {
    display: flex;
    align-items: baseline;
    gap: 10px;
    margin-bottom: 16px;
    padding: 12px 14px;
    background: linear-gradient(95deg, rgba(16,185,129,.08), rgba(6,182,212,.08));
    border: 1px solid rgba(16,185,129,.2);
    border-radius: 12px;
}
.ctm-page .ctm-engage-card__rate span {
    font-size: 12px;
    color: #047857;
    letter-spacing: .1em;
    text-transform: uppercase;
    font-weight: 700;
}
.ctm-page .ctm-engage-card__rate strong {
    font-size: 28px;
    font-weight: 900;
    color: #0b1612;
    letter-spacing: -.02em;
}
.ctm-page .ctm-engage-card__rate strong small { font-size: 14px; font-weight: 600; color: #6b7280; }
.ctm-page .ctm-engage-card__tag {
    font-size: 14px;
    color: #434343;
    margin-bottom: 14px;
    line-height: 1.6;
}
.ctm-page .ctm-engage-card__tag strong { color: #0b1612; }
.ctm-page .ctm-engage-card--featured .ctm-engage-card__tag { color: rgba(209,250,229,.78); }
.ctm-page .ctm-engage-card--featured .ctm-engage-card__tag strong { color: #fff; }
.ctm-page .ctm-engage-card p {
    font-size: 15px;
    line-height: 1.7;
    color: #434343;
    margin: 0 0 20px;
}
.ctm-page .ctm-engage-card--featured p { color: rgba(209,250,229,.78); }
.ctm-page .ctm-engage-card__foot {
    font-size: 14px;
    line-height: 1.6;
    padding-top: 18px;
    border-top: 1px dashed rgba(0,0,0,.1);
}
.ctm-page .ctm-engage-card--featured .ctm-engage-card__foot { border-top-color: rgba(255,255,255,.12); }
.ctm-page .ctm-engage-card__foot strong { display: block; color: var(--ctm-emerald-3); margin-bottom: 4px; }
.ctm-page .ctm-engage-card--featured .ctm-engage-card__foot strong { color: #4ade80; }
.ctm-page .ctm-engage-card__foot span { color: #515564; }
.ctm-page .ctm-engage-card--featured .ctm-engage-card__foot span { color: rgba(209,250,229,.7); }
.ctm-page .ctm-engage-card__corner {
    position: absolute;
    width: 160px; height: 160px;
    bottom: -80px; right: -80px;
    background: radial-gradient(circle, rgba(16,185,129,.18) 0%, transparent 70%);
    border-radius: 50%;
    transition: transform .6s cubic-bezier(.2,.8,.2,1);
    pointer-events: none;
}
.ctm-page .ctm-engage-card:hover .ctm-engage-card__corner { transform: scale(1.6); }


/* =============================================================
   INTERNAL LINKS
============================================================= */
.ctm-page .ctm-links {
    padding: 100px 0 80px;
    background: #fff;
}
.ctm-page .ctm-link-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 28px 26px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    text-decoration: none;
    color: inherit;
    transition: transform .4s ease, border-color .4s ease, box-shadow .4s ease, background .4s ease;
    height: 100%;
}
.ctm-page .ctm-link-card:hover {
    transform: translateY(-4px);
    border-color: rgba(16,185,129,.35);
    background: linear-gradient(135deg, #ffffff 0%, #f0fdf4 100%);
    box-shadow: 0 22px 40px -22px rgba(16,185,129,.3);
    color: inherit;
}
.ctm-page .ctm-link-card__body h3 {
    font-size: 19px;
    font-weight: 700;
    color: #0b1612;
    margin: 0 0 6px;
    line-height: 1.3;
}
.ctm-page .ctm-link-card__body p {
    font-size: 14.5px;
    color: #515564;
    margin: 0;
    line-height: 1.5;
}
.ctm-page .ctm-link-card__arrow {
    width: 44px; height: 44px;
    flex-shrink: 0;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(16,185,129,.12), rgba(6,182,212,.12));
    color: var(--ctm-emerald-3);
    display: inline-flex; align-items: center; justify-content: center;
    transition: transform .4s ease, background .4s ease, color .4s ease;
}
.ctm-page .ctm-link-card:hover .ctm-link-card__arrow {
    transform: translateX(6px);
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
}


/* =============================================================
   FAQ + BLOG (scoped tweaks while keeping legacy markup)
============================================================= */
.ctm-page .ctm-faq { padding-top: 40px; padding-bottom: 80px; }


/* =============================================================
   FEATURE MATRIX  (5 categories × 4-6 chips)
============================================================= */
.ctm-page .ctm-fmatrix {
    padding-top: 50px;
    margin-top: 40px;
    border-top: 1px dashed rgba(16,185,129,.18);
}
.ctm-page .ctm-fmatrix:first-of-type { margin-top: 30px; border-top: 0; padding-top: 0; }
.ctm-page .ctm-fmatrix__head { margin-bottom: 24px; }
.ctm-page .ctm-fmatrix__eyebrow {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--ctm-emerald-3);
    background: linear-gradient(95deg, rgba(16,185,129,.12), rgba(6,182,212,.12));
    border: 1px solid rgba(16,185,129,.25);
    padding: 6px 14px;
    border-radius: 999px;
    margin-bottom: 12px;
}
.ctm-page .ctm-fmatrix__title {
    font-size: clamp(22px, 2.4vw, 30px);
    font-weight: 800;
    line-height: 1.25;
    color: #0b1612;
    margin: 0 0 8px;
    letter-spacing: -.015em;
}
.ctm-page .ctm-fmatrix__desc {
    font-size: 16px;
    line-height: 1.6;
    color: #515564;
    max-width: 760px;
    margin: 0;
}

.ctm-page .ctm-fchip {
    display: flex;
    gap: 14px;
    height: 100%;
    padding: 22px 22px;
    background: #fff;
    border-radius: 16px;
    border: 1px solid rgba(0,0,0,.08);
    transition: transform .4s cubic-bezier(.2,.8,.2,1),
                box-shadow .4s ease,
                border-color .4s ease;
    position: relative;
    overflow: hidden;
}
.ctm-page .ctm-fchip::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(16,185,129,.06) 0%, transparent 60%);
    opacity: 0;
    transition: opacity .4s ease;
    pointer-events: none;
}
.ctm-page .ctm-fchip:hover {
    transform: translateY(-4px);
    border-color: rgba(16,185,129,.4);
    box-shadow: 0 22px 40px -22px rgba(16,185,129,.3);
}
.ctm-page .ctm-fchip:hover::before { opacity: 1; }
.ctm-page .ctm-fchip__icon {
    flex-shrink: 0;
    width: 32px; height: 32px;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--ctm-emerald), var(--ctm-cyan));
    color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    box-shadow: 0 8px 20px -8px rgba(16,185,129,.55);
}
.ctm-page .ctm-fchip h4 {
    font-size: 15.5px;
    font-weight: 700;
    color: #0b1612;
    margin: 0 0 6px;
    letter-spacing: -.005em;
    line-height: 1.3;
}
.ctm-page .ctm-fchip p {
    font-size: 13.5px;
    line-height: 1.55;
    color: #515564;
    margin: 0;
}


/* =============================================================
   GEOGRAPHIC PROJECT DISCOVERY (MAP)
============================================================= */
.ctm-page .ctm-map {
    padding: 100px 0;
    background: #fff;
}
.ctm-page .ctm-map__filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    margin: 0 auto 32px;
    max-width: 920px;
}
.ctm-page .ctm-map__filter {
    border: 1px solid rgba(16,185,129,.22);
    background: #fff;
    color: #0b1612;
    padding: 9px 16px;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    transition: transform .3s ease, background .3s ease, border-color .3s ease, color .3s ease, box-shadow .3s ease;
}
.ctm-page .ctm-map__filter:hover {
    transform: translateY(-2px);
    border-color: rgba(16,185,129,.5);
    background: rgba(16,185,129,.08);
    color: var(--ctm-emerald-3);
}
.ctm-page .ctm-map__filter.is-active {
    background: linear-gradient(95deg, var(--ctm-emerald), var(--ctm-cyan));
    border-color: transparent;
    color: #fff;
    box-shadow: 0 10px 24px -10px rgba(16,185,129,.55);
}

.ctm-page .ctm-map__canvas {
    position: relative;
    height: 520px;
    border-radius: 26px;
    overflow: hidden;
    background: radial-gradient(140% 100% at 50% 0%, #0d1f17 0%, #050b08 90%);
    border: 1px solid rgba(16,185,129,.22);
    isolation: isolate;
}
.ctm-page .ctm-map__bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.ctm-page .ctm-map__grid {
    position: absolute; inset: 0;
    background-image:
        radial-gradient(rgba(74,222,128,.18) 1.5px, transparent 1.6px);
    background-size: 20px 20px;
    /* Carve a rough land-mass silhouette out of the dot grid with a mask */
    mask-image:
        radial-gradient(ellipse 18% 18% at 22% 42%, #000 60%, transparent 80%),
        radial-gradient(ellipse 14% 22% at 19% 64%, #000 60%, transparent 80%),
        radial-gradient(ellipse 18% 12% at 30% 28%, #000 60%, transparent 80%),
        radial-gradient(ellipse 14% 18% at 50% 38%, #000 60%, transparent 80%),
        radial-gradient(ellipse 9%  18% at 56% 68%, #000 60%, transparent 80%),
        radial-gradient(ellipse 22% 14% at 68% 40%, #000 60%, transparent 80%),
        radial-gradient(ellipse 16% 14% at 78% 50%, #000 60%, transparent 80%),
        radial-gradient(ellipse 9%  10% at 87% 72%, #000 60%, transparent 80%);
    -webkit-mask-image:
        radial-gradient(ellipse 18% 18% at 22% 42%, #000 60%, transparent 80%),
        radial-gradient(ellipse 14% 22% at 19% 64%, #000 60%, transparent 80%),
        radial-gradient(ellipse 18% 12% at 30% 28%, #000 60%, transparent 80%),
        radial-gradient(ellipse 14% 18% at 50% 38%, #000 60%, transparent 80%),
        radial-gradient(ellipse 9%  18% at 56% 68%, #000 60%, transparent 80%),
        radial-gradient(ellipse 22% 14% at 68% 40%, #000 60%, transparent 80%),
        radial-gradient(ellipse 16% 14% at 78% 50%, #000 60%, transparent 80%),
        radial-gradient(ellipse 9%  10% at 87% 72%, #000 60%, transparent 80%);
    mask-composite: add;
    -webkit-mask-composite: source-over;
}
.ctm-page .ctm-map__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: .35;
    animation: ctmFloat 18s ease-in-out infinite;
}
.ctm-page .ctm-map__orb--a {
    width: 360px; height: 360px;
    background: #10b981;
    top: -120px; left: -100px;
}
.ctm-page .ctm-map__orb--b {
    width: 360px; height: 360px;
    background: #06b6d4;
    bottom: -120px; right: -100px;
    animation-delay: -8s;
}

.ctm-page .ctm-map__pin {
    position: absolute;
    top: var(--y);
    left: var(--x);
    width: 14px; height: 14px;
    border-radius: 50%;
    background: #4ade80;
    box-shadow: 0 0 0 4px rgba(74,222,128,.22), 0 0 18px rgba(74,222,128,.5);
    transform: translate(-50%, -50%);
    z-index: 2;
    cursor: pointer;
    animation: ctmPinPulse 2.6s ease-in-out infinite;
    animation-delay: calc(var(--x, 0) * .03s);
    transition: opacity .45s ease, transform .45s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-map__pin.is-hidden {
    opacity: .15;
    transform: translate(-50%, -50%) scale(.55);
    pointer-events: none;
    animation-play-state: paused;
}
.ctm-page .ctm-map__callout {
    transition: opacity .45s ease, transform .45s cubic-bezier(.2,.8,.2,1);
}
.ctm-page .ctm-map__callout.is-hidden {
    opacity: 0;
    transform: translateY(8px) scale(.96);
    pointer-events: none;
}
.ctm-page .ctm-map__pin::after {
    content: attr(data-label);
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    transform: translate(-50%, 4px);
    background: rgba(13,31,23,.95);
    border: 1px solid rgba(16,185,129,.4);
    color: #fff;
    font-size: 11.5px;
    font-weight: 600;
    padding: 5px 10px;
    border-radius: 8px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease, transform .3s ease;
    box-shadow: 0 10px 24px -8px rgba(0,0,0,.6);
    z-index: 3;
}
.ctm-page .ctm-map__pin:hover {
    transform: translate(-50%, -50%) scale(1.4);
    background: #34d399;
}
.ctm-page .ctm-map__pin:hover::after {
    opacity: 1;
    transform: translate(-50%, 0);
}
@keyframes ctmPinPulse {
    0%, 100% { box-shadow: 0 0 0 4px rgba(74,222,128,.22), 0 0 18px rgba(74,222,128,.5); }
    50%      { box-shadow: 0 0 0 10px rgba(74,222,128,0),  0 0 24px rgba(74,222,128,.5); }
}

.ctm-page .ctm-map__callout {
    position: absolute;
    width: 250px;
    padding: 16px 18px;
    background: linear-gradient(135deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.02) 100%),
                radial-gradient(140% 140% at 0% 0%, rgba(16,185,129,.18) 0%, rgba(6,182,212,.04) 60%);
    border: 1px solid rgba(16,185,129,.32);
    border-radius: 16px;
    color: #fff;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 30px 60px -25px rgba(0,0,0,.65);
    z-index: 4;
    animation: ctmCardFloat 7s ease-in-out infinite;
}
.ctm-page .ctm-map__callout--a {
    --rot: -2deg;
    top: 28px; left: 18%;
}
.ctm-page .ctm-map__callout--b {
    --rot: 2deg;
    bottom: 28px; right: 6%;
    animation-delay: -3.5s;
}
.ctm-page .ctm-map__callout-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px;
}
.ctm-page .ctm-map__callout-title {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 8px;
    color: #fff;
}
.ctm-page .ctm-map__callout-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 10px;
    font-size: 12.5px;
    color: rgba(255,255,255,.65);
}
.ctm-page .ctm-map__callout-meta b {
    color: #4ade80;
    font-weight: 700;
}
.ctm-page .ctm-map__callout-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.ctm-page .ctm-map__callout-tags i {
    font-style: normal;
    font-size: 10.5px;
    padding: 3px 8px;
    border-radius: 999px;
    background: rgba(16,185,129,.16);
    color: #d1fae5;
    border: 1px solid rgba(74,222,128,.25);
    letter-spacing: .05em;
    font-weight: 600;
}

.ctm-page .ctm-map__stats {
    list-style: none;
    margin: 32px 0 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.ctm-page .ctm-map__stats li {
    text-align: center;
    padding: 22px 14px;
    border-radius: 16px;
    background: linear-gradient(180deg, rgba(16,185,129,.05), transparent);
    border: 1px solid rgba(16,185,129,.16);
    transition: border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.ctm-page .ctm-map__stats li:hover {
    transform: translateY(-3px);
    border-color: rgba(16,185,129,.4);
    box-shadow: 0 18px 36px -22px rgba(16,185,129,.3);
}
.ctm-page .ctm-map__stats strong {
    display: block;
    font-size: clamp(22px, 2.6vw, 30px);
    font-weight: 900;
    color: var(--ctm-emerald-3);
    letter-spacing: -.02em;
    line-height: 1;
    margin-bottom: 6px;
}
.ctm-page .ctm-map__stats span {
    font-size: 13px;
    color: #515564;
    font-weight: 600;
    letter-spacing: .03em;
}


/* =============================================================
   REGISTRIES / STANDARDS / FRAMEWORKS LOGO WALL
============================================================= */
.ctm-page .ctm-stack {
    padding: 100px 0;
    background: linear-gradient(180deg, #f0fdf4 0%, #ffffff 100%);
}
.ctm-page .ctm-stack__group {
    margin-top: 30px;
    padding: 22px 26px;
    background: #fff;
    border-radius: 18px;
    border: 1px solid rgba(16,185,129,.14);
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 26px;
    align-items: center;
    transition: border-color .4s ease, box-shadow .4s ease;
}
.ctm-page .ctm-stack__group:hover {
    border-color: rgba(16,185,129,.35);
    box-shadow: 0 22px 40px -24px rgba(16,185,129,.25);
}
.ctm-page .ctm-stack__label {
    font-size: 13px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--ctm-emerald-3);
}
.ctm-page .ctm-stack__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 10px;
}
.ctm-page .ctm-stack__chips span {
    display: inline-flex;
    align-items: center;
    padding: 8px 14px;
    background: linear-gradient(95deg, rgba(16,185,129,.06), rgba(6,182,212,.06));
    border: 1px solid rgba(16,185,129,.2);
    color: #0b1612;
    font-size: 13px;
    font-weight: 600;
    border-radius: 999px;
    transition: transform .3s ease, background .3s ease, border-color .3s ease, color .3s ease;
    cursor: default;
}
.ctm-page .ctm-stack__chips span:hover {
    transform: translateY(-2px);
    background: linear-gradient(95deg, var(--ctm-emerald), var(--ctm-cyan));
    border-color: transparent;
    color: #fff;
    box-shadow: 0 10px 20px -10px rgba(16,185,129,.45);
}


/* =============================================================
   BLOCKCHAIN & TOKENIZATION
============================================================= */
.ctm-page .ctm-chain {
    position: relative;
    padding: 130px 0;
    background: radial-gradient(120% 80% at 50% 0%, #0d1f17 0%, #050b08 80%);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-chain__bg { position: absolute; inset: 0; z-index: -1; }
.ctm-page .ctm-chain__grid {
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 85%);
    -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, #000 30%, transparent 85%);
}
.ctm-page .ctm-chain__orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(110px);
    opacity: .35;
    animation: ctmFloat 18s ease-in-out infinite;
}
.ctm-page .ctm-chain__orb--a {
    width: 480px; height: 480px;
    background: #06b6d4;
    top: -160px; right: -100px;
}
.ctm-page .ctm-chain__orb--b {
    width: 460px; height: 460px;
    background: #10b981;
    bottom: -160px; left: -100px;
    animation-delay: -7s;
}
.ctm-page .ctm-chain__lead {
    font-size: 17px;
    line-height: 1.75;
    color: rgba(209,250,229,.78);
    margin: 18px 0 22px;
}
.ctm-page .ctm-chain__points {
    list-style: none;
    padding: 0; margin: 0;
    display: flex; flex-direction: column;
    gap: 12px;
}
.ctm-page .ctm-chain__points li {
    display: flex; align-items: flex-start;
    gap: 12px;
    font-size: 15px;
    line-height: 1.65;
    color: rgba(209,250,229,.78);
}

/* circular chain visual */
.ctm-page .ctm-chain__viz {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    max-width: 480px;
    margin: 0 auto;
}
.ctm-page .ctm-chain__core {
    position: absolute;
    top: 50%; left: 50%;
    width: 32%;
    aspect-ratio: 1 / 1;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    background: linear-gradient(135deg, #052e1b, #0a4a3a);
    border: 1.5px solid rgba(74,222,128,.55);
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 0 60px rgba(74,222,128,.35),
                inset 0 0 30px rgba(74,222,128,.15);
    z-index: 3;
}
.ctm-page .ctm-chain__core-ring,
.ctm-page .ctm-chain__core-ring--2 {
    position: absolute;
    top: 50%; left: 50%;
    width: 60%;
    aspect-ratio: 1 / 1;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    border: 1px dashed rgba(74,222,128,.35);
    animation: ctmSpin 28s linear infinite;
    z-index: 1;
    pointer-events: none;
}
.ctm-page .ctm-chain__core-ring--2 {
    width: 84%;
    border-style: dotted;
    border-color: rgba(56,189,248,.25);
    animation: ctmSpin 40s linear infinite reverse;
}
.ctm-page .ctm-chain__core-label {
    text-align: center;
    line-height: 1.1;
}
.ctm-page .ctm-chain__core-label strong {
    display: block;
    font-size: clamp(20px, 2.5vw, 30px);
    font-weight: 900;
    color: #4ade80;
    letter-spacing: -.02em;
}
.ctm-page .ctm-chain__core-label span {
    font-size: 11px;
    color: rgba(255,255,255,.55);
    letter-spacing: .12em;
    text-transform: uppercase;
}
.ctm-page .ctm-chain__nodes {
    position: absolute;
    inset: 0;
}
.ctm-page .ctm-chain__node {
    position: absolute;
    top: 50%; left: 50%;
    width: 84px; height: 84px;
    transform: translate(-50%, -50%) rotate(var(--a)) translateY(-42%) rotate(calc(var(--a) * -1));
    border-radius: 16px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    box-shadow: 0 18px 40px -20px rgba(0,0,0,.6);
    transition: transform .4s ease, background .4s ease, border-color .4s ease;
    z-index: 2;
}
.ctm-page .ctm-chain__node:hover {
    background: rgba(16,185,129,.16);
    border-color: rgba(74,222,128,.55);
    transform: translate(-50%, -50%) rotate(var(--a)) translateY(-42%) rotate(calc(var(--a) * -1)) scale(1.08);
}
.ctm-page .ctm-chain__node b {
    font-size: 13px;
    font-weight: 700;
    color: #4ade80;
    letter-spacing: .05em;
}
.ctm-page .ctm-chain__node i {
    font-style: normal;
    font-size: 10px;
    color: rgba(255,255,255,.55);
    letter-spacing: .05em;
    margin-top: 2px;
}
.ctm-page .ctm-chain__wallets {
    margin-top: 22px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
}
.ctm-page .ctm-chain__wallets span {
    padding: 7px 14px;
    border-radius: 999px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(255,255,255,.12);
    color: rgba(209,250,229,.78);
    font-size: 12px;
    font-weight: 600;
}


/* =============================================================
   CARBON FOOTPRINT CALCULATOR BAND
============================================================= */
.ctm-page .ctm-calc {
    padding: 0 0 100px;
}
.ctm-page .ctm-calc__card {
    position: relative;
    padding: 60px 50px;
    border-radius: 30px;
    background: radial-gradient(120% 100% at 0% 0%, #0d1f17 0%, #050b08 80%);
    color: #fff;
    overflow: hidden;
    isolation: isolate;
}
.ctm-page .ctm-calc__bg { position: absolute; inset: 0; z-index: -1; pointer-events: none; }
.ctm-page .ctm-calc__shape {
    position: absolute;
    border-radius: 50%;
    filter: blur(90px);
    opacity: .45;
    animation: ctmFloat 14s ease-in-out infinite;
}
.ctm-page .ctm-calc__shape--a { width: 380px; height: 380px; background: #10b981; top: -120px; right: -100px; }
.ctm-page .ctm-calc__shape--b { width: 320px; height: 320px; background: #06b6d4; bottom: -120px; left: -80px; animation-delay: -6s; }

.ctm-page .ctm-calc__card h2 {
    margin-top: 12px;
    margin-bottom: 14px;
}
.ctm-page .ctm-calc__lead {
    font-size: 16px;
    line-height: 1.75;
    color: rgba(209,250,229,.78);
    margin-bottom: 18px;
}
.ctm-page .ctm-calc__points {
    list-style: none;
    padding: 0; margin: 0 0 28px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 18px;
}
.ctm-page .ctm-calc__points li {
    display: flex; align-items: flex-start;
    gap: 12px;
    font-size: 14.5px;
    line-height: 1.55;
    color: rgba(209,250,229,.78);
}

.ctm-page .ctm-calc__mock {
    background: linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.02) 100%);
    border: 1px solid rgba(16,185,129,.3);
    border-radius: 22px;
    padding: 22px 22px;
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    box-shadow: 0 30px 60px -30px rgba(0,0,0,.7);
}
.ctm-page .ctm-calc__mock-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}
.ctm-page .ctm-calc__field {
    padding: 14px 16px;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px;
    margin-bottom: 10px;
}
.ctm-page .ctm-calc__field label {
    display: block;
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(167,243,208,.65);
    font-weight: 700;
    margin-bottom: 4px;
}
.ctm-page .ctm-calc__value {
    font-size: 17px;
    font-weight: 700;
    color: #fff;
}
.ctm-page .ctm-calc__value strong {
    font-size: 28px;
    font-weight: 900;
    color: #4ade80;
    letter-spacing: -.02em;
}
.ctm-page .ctm-calc__value small {
    font-size: 12px;
    font-weight: 600;
    opacity: .65;
    margin-left: 4px;
}
.ctm-page .ctm-calc__match {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 4px;
}
.ctm-page .ctm-calc__match span {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: rgba(255,255,255,.85);
}
.ctm-page .ctm-calc__match span::before {
    content: "";
    width: 6px; height: 6px;
    background: #4ade80;
    border-radius: 50%;
    box-shadow: 0 0 0 3px rgba(74,222,128,.18);
}
.ctm-page .ctm-calc__total {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: 14px 16px;
    margin-top: 8px;
    border-top: 1px dashed rgba(255,255,255,.12);
}
.ctm-page .ctm-calc__total span {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: rgba(167,243,208,.6);
    font-weight: 700;
}
.ctm-page .ctm-calc__total strong {
    font-size: 28px;
    font-weight: 900;
    color: #4ade80;
    letter-spacing: -.02em;
}
.ctm-page .ctm-calc__cta {
    text-align: center;
    margin-top: 10px;
    padding: 12px;
    background: linear-gradient(95deg, var(--ctm-red), var(--ctm-red-2));
    color: #fff;
    border-radius: 12px;
    font-weight: 700;
    font-size: 14px;
    letter-spacing: .04em;
    box-shadow: 0 14px 30px -12px rgba(236,32,36,.55);
    position: relative;
    overflow: hidden;
}
.ctm-page .ctm-calc__cta::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
    transform: translateX(-100%);
    animation: ctmShimmer 3s ease-in-out infinite;
}


/* =============================================================
   STICKY BOTTOM CTA BAR
   Hidden by default; JS toggles `.ctm-sticky--visible` on reverse
   (upward) scroll once the user has passed the hero.
============================================================= */
.ctm-page ~ .ctm-sticky,
.ctm-page .ctm-sticky {
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 1040;
    background: linear-gradient(180deg, rgba(13,31,23,.94) 0%, rgba(5,11,8,.97) 100%);
    border-top: 1px solid rgba(16,185,129,.3);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    color: #fff;
    transform: translateY(120%);
    transition: transform .5s cubic-bezier(.2,.8,.2,1);
    box-shadow: 0 -20px 50px -20px rgba(0,0,0,.6);
    will-change: transform;
}
.ctm-page .ctm-sticky--visible { transform: translateY(0); }
.ctm-page .ctm-sticky--dismissed { transform: translateY(120%) !important; }
.ctm-page .ctm-sticky__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 14px 16px;
}
.ctm-page .ctm-sticky__copy { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.ctm-page .ctm-sticky__copy strong { font-size: 15px; font-weight: 700; color: #fff; }
.ctm-page .ctm-sticky__copy span { font-size: 12.5px; color: rgba(209,250,229,.7); }
.ctm-page .ctm-sticky__actions {
    display: flex;
    gap: 10px;
    flex-shrink: 0;
}
.ctm-page .ctm-sticky__actions .ctm-btn { padding: 10px 18px; font-size: 13.5px; border-radius: 10px; }
.ctm-page .ctm-sticky__close {
    flex-shrink: 0;
    width: 28px; height: 28px;
    border: 0;
    background: rgba(255,255,255,.06);
    color: rgba(255,255,255,.7);
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background .3s ease, color .3s ease;
}
.ctm-page .ctm-sticky__close:hover { background: rgba(255,255,255,.12); color: #fff; }

/* push the FAQ section up a touch so the sticky doesn't overlap the last accordion */
.ctm-page .ctm-faq { padding-bottom: 120px; }


/* =============================================================
   RESPONSIVE
============================================================= */
@media (max-width: 1199.98px) {
    .ctm-page .ctm-section-head--split { grid-template-columns: 1fr; gap: 22px; align-items: start; }
    .ctm-page .ctm-life__steps,
    .ctm-page .ctm-life__steps--six { grid-template-columns: repeat(3, 1fr); }
    .ctm-page .ctm-life__line { display: none; }
    .ctm-page .ctm-engage-card--featured { transform: translateY(0); }
    .ctm-page .ctm-engage-card--featured:hover { transform: translateY(-8px); }
    .ctm-page .ctm-stack__group { grid-template-columns: 1fr; gap: 14px; }
    .ctm-page .ctm-chain__viz { max-width: 420px; }
    .ctm-page .ctm-map__canvas { height: 460px; }
    .ctm-page .ctm-map__callout { width: 220px; padding: 12px 14px; }
    .ctm-page .ctm-map__stats { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 991.98px) {
    .ctm-page .ctm-stack, .ctm-page .ctm-chain, .ctm-page .ctm-calc { padding: 80px 0; }
    .ctm-page .ctm-calc__card { padding: 40px 28px; }
    .ctm-page .ctm-calc__points { grid-template-columns: 1fr; }
    .ctm-page .ctm-chain__viz { max-width: 360px; aspect-ratio: 1 / 1; }
    .ctm-page .ctm-chain__node { width: 70px; height: 70px; }
    .ctm-page .ctm-what__stats { grid-template-columns: 1fr 1fr; }
    .ctm-page .ctm-sticky__copy span { display: none; }
    .ctm-page .ctm-sticky__copy strong { font-size: 14px; }
    .ctm-page .ctm-hero { padding: 100px 0 60px; }
    .ctm-page .ctm-hero__visual {
        min-height: 0;
        margin-top: 40px;
        padding: 30px 16px 90px;
    }
    .ctm-page .ctm-console {
        max-width: 460px;
        transform: rotate(0deg);
        animation: none;
    }
    .ctm-page .ctm-hbadge--reg {
        top: -12px;
        right: 0;
        --rot: 0deg;
    }
    .ctm-page .ctm-hbadge--cert {
        left: 0;
        bottom: 50px;
        --rot: 0deg;
    }
    .ctm-page .ctm-hbadge--chain {
        right: 0;
        bottom: -10px;
        --rot: 0deg;
    }
    .ctm-page .ctm-hero__leaf { display: none; }
    .ctm-page .ctm-what { padding: 90px 0; }
    .ctm-page .ctm-roles, .ctm-page .ctm-features, .ctm-page .ctm-compliance,
    .ctm-page .ctm-admin, .ctm-page .ctm-monetize, .ctm-page .ctm-proto,
    .ctm-page .ctm-arch, .ctm-page .ctm-engage { padding: 90px 0; }
    .ctm-page .ctm-lifecycle { padding: 90px 0; }
    .ctm-page .ctm-cta__card { padding: 60px 30px; }
    .ctm-page .ctm-proto__price {
        position: relative;
        top: 0; left: 0;
        display: inline-block;
        margin-bottom: 18px;
    }
}

@media (max-width: 767.98px) {
    .ctm-page .ctm-hero__stats { grid-template-columns: repeat(2, 1fr); gap: 18px; }
    .ctm-page .ctm-hero__visual { padding: 24px 8px 70px; }
    .ctm-page .ctm-console { max-width: 100%; padding: 18px 16px; }
    .ctm-page .ctm-console__hero-value strong { font-size: 30px; }
    .ctm-page .ctm-console__feed-track { height: 110px; }
    .ctm-page .ctm-hbadge--reg { width: 168px; padding: 10px 12px; top: -10px; right: -4px; }
    .ctm-page .ctm-hbadge--cert { width: 200px; padding: 10px 12px; left: -4px; bottom: 42px; }
    .ctm-page .ctm-hbadge--chain { width: 188px; padding: 10px 12px; right: -4px; bottom: -8px; }
    .ctm-page .ctm-hbadge--cert strong,
    .ctm-page .ctm-hbadge--chain strong { font-size: 11.5px; }
    .ctm-page .ctm-hbadge--cert span,
    .ctm-page .ctm-hbadge--chain span { font-size: 10px; }
    .ctm-page .ctm-what__stats { grid-template-columns: 1fr; gap: 14px; }
    .ctm-page .ctm-fmatrix { padding-top: 36px; margin-top: 28px; }
    .ctm-page .ctm-map { padding: 70px 0; }
    .ctm-page .ctm-map__canvas { height: 360px; }
    .ctm-page .ctm-map__callout { width: 180px; padding: 10px 12px; font-size: 12px; }
    .ctm-page .ctm-map__callout-title { font-size: 14px; }
    .ctm-page .ctm-map__callout--a { top: 14px; left: 8px; }
    .ctm-page .ctm-map__callout--b { bottom: 14px; right: 8px; }
    .ctm-page .ctm-map__pin::after { display: none; }
    .ctm-page .ctm-map__stats { grid-template-columns: 1fr 1fr; gap: 10px; }
    .ctm-page .ctm-stack__chips span { font-size: 12px; padding: 6px 11px; }
    .ctm-page .ctm-chain__node { width: 60px; height: 60px; }
    .ctm-page .ctm-chain__node b { font-size: 11px; }
    .ctm-page .ctm-chain__node i { font-size: 9px; }
    .ctm-page .ctm-sticky__actions .ctm-btn--ghost { display: none; }
    .ctm-page .ctm-life__steps,
    .ctm-page .ctm-life__steps--six { grid-template-columns: 1fr; }
    .ctm-page .ctm-roles, .ctm-page .ctm-features, .ctm-page .ctm-compliance,
    .ctm-page .ctm-admin, .ctm-page .ctm-monetize, .ctm-page .ctm-proto,
    .ctm-page .ctm-arch, .ctm-page .ctm-engage, .ctm-page .ctm-what { padding: 70px 0; }
    .ctm-page .ctm-cta__card { padding: 48px 22px; border-radius: 22px; }
    .ctm-page .ctm-hero__marquee { margin-top: 50px; }
    .ctm-page .ctm-marquee__track span { font-size: 11px; }
    .ctm-page .ctm-section-head { margin-bottom: 40px; }
    .ctm-page .ctm-feature-card h3 { min-height: auto; }
    .ctm-page .ctm-money-card h3 { min-height: auto; }
    .ctm-page .ctm-admin__divider { margin: 50px 0; }
    .ctm-page .ctm-what__badge { right: 12px; padding: 10px 14px; }
}

@media (prefers-reduced-motion: reduce) {
    .ctm-page *,
    .ctm-page *::before,
    .ctm-page *::after {
        animation-duration: .01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: .01ms !important;
    }
    .ctm-page .ctm-reveal { opacity: 1; transform: none; }
}
