        *,
        *::before,
        *::after {
            box-sizing: border-box;
            margin: 0;
            padding: 0
        }

        /* ══ TOKENS ══════════════════════════════════ */
        [data-theme="light"] {
            /* Page background — warm stone grey, easy on the eyes */
            --bg:    #D6D3CE;
            /* Slightly lighter surface for sections/panels */
            --bg2:   #DDD9D4;
            /* Card/elevated surface — noticeably lighter */
            --bg3:   #E5E2DC;
            /* Card overlays */
            --card:  rgba(232, 228, 220, 0.8);
            --card2: rgba(238, 234, 226, 0.9);
            /* Borders */
            --border:  rgba(0, 0, 0, 0.1);
            --border2: rgba(0, 0, 0, 0.2);
            /* Text — deep charcoal for primary, softer for secondary */
            --text:  #1C1A18;
            --text2: #4A4540;
            --text3: #8A8480;
            /* Accent — amber/gold, deepened for daylight contrast */
            --acc:      #B88800;
            --acc2:     #9A7000;
            --acc-dim:  rgba(184, 136, 0, 0.12);
            --acc-b:    rgba(184, 136, 0, 0.28);
            --shadow:   rgba(0, 0, 0, 0.12);
            --gold:     #B88800;
            --gold-dim: rgba(184, 136, 0, 0.14);
            --rule:     rgba(0, 0, 0, 0.09);
        }

        [data-theme="dark"] {
            --bg: #0D0D0D;
            --bg2: #141414;
            --bg3: #1A1A1A;
            --card: rgba(22, 22, 22, 0.7);
            --card2: rgba(28, 28, 28, 0.85);
            --border: rgba(255, 255, 255, 0.08);
            --border2: rgba(255, 255, 255, 0.14);
            --text: #F8F8F8;
            --text2: #A3A3A3;
            --text3: #525252;
            --acc: #F5B800;
            --acc2: #D4A000;
            --acc-dim: rgba(245, 184, 0, 0.08);
            --acc-b: rgba(245, 184, 0, 0.22);
            --shadow: rgba(0, 0, 0, 0.8);
            --gold: #F5B800;
            --gold-dim: rgba(245, 184, 0, 0.12);
            --rule: rgba(255, 255, 255, 0.08);
        }


        /* ══ LIGHT MODE OVERRIDES ═══════════════════ */
        /* Primary accent switches to blue across entire page in light mode */
        [data-theme="light"] {
            --acc:     #1A6FD4;
            --acc2:    #1258B0;
            --acc-dim: rgba(26, 111, 212, 0.1);
            --acc-b:   rgba(26, 111, 212, 0.25);
            --gold:    #1A6FD4;
            --gold-dim: rgba(26, 111, 212, 0.12);
        }

        /* Masthead — override its own hardcoded green tokens */
        [data-theme="light"] .masthead {
            --acc:     #1A6FD4;
            --acc2:    #1258B0;
            --acc-dim: rgba(26, 111, 212, 0.08);
            --acc-b:   rgba(26, 111, 212, 0.22);
            --gold:    #1A6FD4;
        }

        /* Masthead logo SVG — override hardcoded green fill */
        [data-theme="light"] .mast-kicker-logo svg path { fill: #1A6FD4; }

        /* Masthead location pin */
        [data-theme="light"] .mast-loc svg { stroke: #1A6FD4; }

        /* Custom cursor */
        [data-theme="light"] #cursor { background: #1A6FD4; }
        [data-theme="light"] #cursor-ring { border-color: rgba(26, 111, 212, .4); }

        /* ── Page base ── */
        [data-theme="light"] body {
            background-color: var(--bg);
        }

        /* ── Stats — solid colour matching their accent ── */
        [data-theme="light"] .stat:nth-child(1) { background: #1A6645; border-color: rgba(57,255,154,.3) !important; }
        [data-theme="light"] .stat:nth-child(2) { background: #9F1239; border-color: rgba(244,63,94,.3) !important; }
        [data-theme="light"] .stat:nth-child(3) { background: #92610A; border-color: rgba(245,184,0,.3) !important; }
        [data-theme="light"] .stat-l { color: #F8F8F8; }

        /* ── srv chips — solid colour matching their service card ── */
        [data-theme="light"] .srv[data-target="svc-design"]    { background: #1A6645; border-color: rgba(57,255,154,.3); }
        [data-theme="light"] .srv[data-target="svc-dev"]       { background: #3730A3; border-color: rgba(129,140,248,.3); }
        [data-theme="light"] .srv[data-target="svc-broadcast"] { background: #9F1239; border-color: rgba(244,63,94,.3); }
        [data-theme="light"] .srv[data-target="svc-it"]        { background: #92610A; border-color: rgba(251,191,36,.3); }
        [data-theme="light"] .srv[data-target="svc-comms"]     { background: #7E22CE; border-color: rgba(232,121,249,.3); }
        [data-theme="light"] .srv[data-target="svc-pm"]        { background: #0F766E; border-color: rgba(45,212,191,.3); }
        [data-theme="light"] .srv[data-target="svc-coaching"]  { background: #9A3412; border-color: rgba(251,146,60,.3); }
        [data-theme="light"] .srv[data-target="svc-events"]    { background: #1D4ED8; border-color: rgba(96,165,250,.3); }
        [data-theme="light"] .srv-label { color: #F8F8F8; }

        /* ── Service accordion cards — solid colours, readable on light ── */
        [data-theme="light"] #svc-design   { background-color: #1A6645; --svc-bg:#1A6645; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-dev      { background-color: #3730A3; --svc-bg:#3730A3; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-broadcast{ background-color: #9F1239; --svc-bg:#9F1239; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-it       { background-color: #92610A; --svc-bg:#92610A; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-comms    { background-color: #7E22CE; --svc-bg:#7E22CE; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-pm       { background-color: #0F766E; --svc-bg:#0F766E; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-coaching { background-color: #9A3412; --svc-bg:#9A3412; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }
        [data-theme="light"] #svc-events   { background-color: #1D4ED8; --svc-bg:#1D4ED8; background-image: url('../img/lowpoly.png'); background-repeat: repeat; background-attachment: fixed; }

        [data-theme="light"] .service-card:hover { filter: brightness(1.1); }

        /* Service card text stays white on solid dark backgrounds */
        [data-theme="light"] .service-title { color: #F8F8F8; }
        [data-theme="light"] .service-desc  { color: rgba(255,255,255,.8); }

        /* stags — white on solid dark card bgs */
        [data-theme="light"] .stag {
            color: rgba(255,255,255,.85);
            border-color: rgba(255,255,255,.2);
            background: rgba(255,255,255,.1);
        }

        /* ── Tool chips ── */
        [data-theme="light"] .tool-icon-white { filter: invert(1); }
        [data-theme="light"] .tool-chip {
            background: #EDEAE4;
            border-color: rgba(0,0,0,.1);
            color: var(--text2);
        }
        [data-theme="light"] .tool-chip:hover { color: var(--text); border-color: rgba(0,0,0,.22); }

        /* ── Project cards — solid colours matching dark mode identity ── */
        [data-theme="light"] .lcard:nth-child(1) {
            background: linear-gradient(135deg, #1A7A45 0%, #1A3A8A 100%) !important;
            border-color: rgba(59,130,246,.4) !important;
        }
        [data-theme="light"] .lcard:nth-child(2) {
            background: linear-gradient(135deg, #C4203A 0%, #C45A10 100%) !important;
            border-color: rgba(220,60,20,.4) !important;
        }
        [data-theme="light"] .lcard-title { color: #F8F8F8 !important; }
        [data-theme="light"] .lcard-sub   { color: rgba(255,255,255,.8) !important; }
        [data-theme="light"] .lcard-eye   { color: rgba(255,255,255,.6) !important; }

        /* ── Quote block — yellow in light mode ── */
        [data-theme="light"] .quote-block {
            background: linear-gradient(135deg, #F5B800 0%, #E0A800 100%) !important;
            border-color: rgba(180,130,0,0.4) !important;
        }
        [data-theme="light"] .quote-text { color: #0D0D0D !important; }
        [data-theme="light"] .quote-icon { color: rgba(0,0,0,0.35) !important; }

        /* ── Contact card ── */
        [data-theme="light"] .contact-link {
            background: linear-gradient(135deg, #9ABFE8 0%, #85AADC 100%) !important;
            border-color: rgba(59,130,246,.4) !important;
        }


        /* ── Contact card full light override ── */
        [data-theme="light"] .contact-card {
            background: linear-gradient(135deg, #F5B800 0%, #E0A800 100%) !important;
            border-color: rgba(180,130,0,0.4) !important;
        }
        [data-theme="light"] .contact-card > div:first-child {
            background: #D4A000 !important;
        }
        [data-theme="light"] .contact-card > div:first-child > div:first-child {
            border-top-color: #B8880A !important;
        }
        [data-theme="light"] .contact-card p { color: #0D0D0D !important; }
        [data-theme="light"] .contact-card p:last-of-type { color: rgba(0,0,0,0.6) !important; }
        [data-theme="light"] .avail-text { color: rgba(0,0,0,0.5) !important; }
        /* pill + stamp + send button on yellow bg */
        [data-theme="light"] .contact-card svg[stroke="#3B82F6"] { stroke: rgba(0,0,0,0.5) !important; }
        [data-theme="light"] .contact-card [style*="border-radius:50%"] { background: rgba(0,0,0,0.1) !important; border-color: rgba(0,0,0,0.2) !important; }
        [data-theme="light"] .contact-card [style*="background:rgba(59,130,246,0.15)"] { background: rgba(0,0,0,0.1) !important; border-color: rgba(0,0,0,0.2) !important; }
        [data-theme="light"] .contact-card [style*="color:#3B82F6"] { color: rgba(0,0,0,0.6) !important; }
        [data-theme="light"] .contact-card [style*="background:#3B82F6"] { background: #1A0E00 !important; }
        [data-theme="light"] .contact-card [style*="border-top:1px solid rgba(59,130,246"] { border-top-color: rgba(0,0,0,0.15) !important; }

        /* Contact card text on light bg */
        [data-theme="light"] .contact-link .cl-to,
        [data-theme="light"] .contact-link .cl-msg,
        [data-theme="light"] .contact-link .cl-sub,
        [data-theme="light"] .contact-link .cl-avail { color: var(--text) !important; }
        [data-theme="light"] .contact-link .cl-send { color: #1A6FD4 !important; }

        /* ── General text ── */
        [data-theme="light"] .mast-domain,
        [data-theme="light"] .mast-bio,
        [data-theme="light"] .mast-name,
        [data-theme="light"] .sec-title,
        [data-theme="light"] .foot-l { color: var(--text); }

        [data-theme="light"] .mast-role .role-item,
        [data-theme="light"] .mast-loc { color: var(--text2); }

        [data-theme="light"] .mast-domain { color: var(--text3); }

        /* ── Social buttons ── */
        [data-theme="light"] .soc {
            background: #EDEAE4;
            border-color: rgba(0,0,0,.1);
        }
        [data-theme="light"] .soc-n { color: var(--text2); }

        /* ── Preloader light mode ── */
        [data-theme="light"] #preloader { background: #D6D3CE; }
        [data-theme="light"] .pre-logo path { fill: #1A6FD4; }
        [data-theme="light"] .pre-l { color: var(--text); }
        [data-theme="light"] .pre-l.acc { color: #1A6FD4; }
        [data-theme="light"] #pl-n, [data-theme="light"] #pl-i, [data-theme="light"] #pl-c,
        [data-theme="light"] #pl-o, [data-theme="light"] #pl-l, [data-theme="light"] #pl-s { color: #1A6FD4; }
        [data-theme="light"] .pre-word { color: var(--text2); }
        [data-theme="light"] .pre-word span { color: #1A6FD4; }
        [data-theme="light"] .pre-dot { color: #1A6FD4; }
        [data-theme="light"] .pre-bar-wrap { background: rgba(0,0,0,.12); }
        [data-theme="light"] .pre-bar { background: #1A6FD4; }
        [data-theme="light"] .pre-tagline { color: var(--text3); }

        /* ══ BASE ════════════════════════════════════ */
        html {
            scroll-behavior: smooth;
            overflow-x: hidden;
        }

        body {
            background-color: var(--bg);
            background-image: url('../img/lowpoly.png');
            background-repeat: repeat;
            background-attachment: fixed;
            color: var(--text);
            font-family: 'Plus Jakarta Sans', sans-serif;
            min-height: 100vh;
            overflow-x: hidden;
            transition: background .4s, color .4s;
        }


        /* ══ PRELOADER ═══════════════════════════════ */
        #preloader {
            position: fixed;
            inset: 0;
            background: #0D0D0D;
            z-index: 9999;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: .5rem;
            transition: opacity .7s ease, visibility .7s ease;
        }

        #preloader.done {
            opacity: 0;
            visibility: hidden
        }

        .pre-logo {
            width: clamp(64px, 18vw, 120px);
            height: auto;
            opacity: 0;
            animation: preLogoIn .8s cubic-bezier(0.22,1,0.36,1) .1s forwards;
        }

        @keyframes preLogoIn {
            from { opacity: 0; transform: translateY(-12px); }
            to   { opacity: 1; transform: translateY(0); }
        }

        .pre-letters {
            display: flex;
            gap: 0;
            position: relative;
        }

        .pre-l {
            font-family: 'Playfair Display', serif;
            font-size: clamp(2rem, 6vw, 4rem);
            font-weight: 900;
            line-height: .95;
            letter-spacing: -.02em;
            color: #F0F0F0;
            opacity: 0;
            transform: translateY(40px);
            transition: opacity .5s ease, transform .5s ease, color .4s;
        }

        #pl-n, #pl-i, #pl-c, #pl-o, #pl-l, #pl-s {
            font-style: italic;
            font-weight: 500;
            color: #39FF9A;
            letter-spacing: .01em;
        }

        .pre-l.acc {
            color: #39FF9A
        }

        .pre-l.show {
            opacity: 1;
            transform: translateY(0)
        }

        .pre-words {
            display: flex;
            flex-direction: row;
            align-items: center;
            flex-wrap: wrap;
            justify-content: center;
            gap: .5rem .4rem;
            opacity: 0;
            transition: opacity .6s ease;
            max-width: 90vw;
            text-align: center;
        }

        .pre-words.show {
            opacity: 1
        }

        .pre-dot { color: #39FF9A; }

        .pre-word {
            font-family: 'DM Mono', monospace;
            font-size: clamp(.6rem, 2vw, .8rem);
            font-weight: 500;
            letter-spacing: .08em;
            text-transform: uppercase;
            color: #bbb;
            display: flex;
            align-items: center;
            white-space: nowrap;
        }

        .pre-word span {
            color: #39FF9A
        }

        .pre-bar-wrap {
            width: 160px;
            height: 1px;
            background: #222;
            position: relative;
            overflow: hidden;
            opacity: 0;
            transition: opacity .4s ease;
        }

        .pre-bar-wrap.show {
            opacity: 1
        }

        .pre-bar {
            position: absolute;
            top: 0;
            left: 0;
            height: 100%;
            width: 0%;
            background: #39FF9A;
            transition: width 1.8s cubic-bezier(.4, 0, .2, 1);
        }

        .pre-bar.go {
            width: 100%
        }

        .pre-tagline {
            font-family: 'DM Mono', monospace;
            font-size: .58rem;
            letter-spacing: .25em;
            text-transform: uppercase;
            color: #2A2A2A;
            opacity: 0;
            text-align: center;
            transition: opacity .5s ease;
        }

        .pre-tagline.show {
            opacity: 1
        }

        /* ══ THEME BUTTON ════════════════════════════ */
        /* ══ PAGE SHELL ══════════════════════════════ */
        .page {
            position: relative;
            z-index: 1;
            max-width: 600px;
            width: 100%;
            margin: 0 auto;
            padding: 0 1.5rem 3rem;
            opacity: 0;
            transition: opacity .8s ease .3s;
        }

        .page.show {
            opacity: 1
        }

        /* ══ NOISE TEXTURE ══════════════════════════ */
        body::before {
            content: '';
            position: fixed;
            inset: 0;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
            opacity: .03;
            pointer-events: none;
            z-index: 9999;
        }

        /* ══ CUSTOM CURSOR ══════════════════════════ */
        @media (pointer: fine) {
            body { cursor: none; }

            #cursor {
                width: 10px;
                height: 10px;
                background: #39FF9A;
                border-radius: 50%;
                position: fixed;
                top: 0; left: 0;
                pointer-events: none;
                z-index: 99999;
                transform: translate(-50%, -50%);
                transition: width .2s, height .2s;
                mix-blend-mode: normal;
            }

            #cursor-ring {
                width: 36px;
                height: 36px;
                border: 1px solid rgba(57, 255, 154, .35);
                border-radius: 50%;
                position: fixed;
                top: 0; left: 0;
                pointer-events: none;
                z-index: 99998;
                transform: translate(-50%, -50%);
                transition: width .3s, height .3s, border-color .3s;
            }
        }

        @media (pointer: coarse) {
            #cursor, #cursor-ring { display: none; }
        }

        /* ══ SCROLL CUE ══════════════════════════════ */
        .scroll-cue {
            display: flex;
            align-items: center;
            gap: 1rem;
            padding: 1rem 0 .5rem;
            opacity: 0;
            animation: fadeIn 1s ease 1.3s forwards;
        }

        .scroll-line {
            width: 40px;
            height: 1px;
            background: var(--border2);
            position: relative;
            overflow: hidden;
        }

        .scroll-line::after {
            content: '';
            position: absolute;
            left: -100%;
            top: 0;
            width: 100%;
            height: 100%;
            background: var(--acc);
            animation: scan 2.2s ease-in-out infinite;
        }

        @keyframes scan {
            to { left: 100% }
        }

        .scroll-cue-text {
            font-family: 'DM Mono', monospace;
            font-size: .58rem;
            letter-spacing: .2em;
            color: var(--text3);
            text-transform: uppercase;
        }

        /* ══ STATS STRIP ═════════════════════════════ */
        .stats-strip {
            border-top: 1px solid var(--border);
            border-bottom: 1px solid var(--border);
            background: var(--bg2);
            transition: background .4s, border-color .4s;
        }

        .stats-inner {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            max-width: 720px;
            margin: 0 auto;
        }

        .stat-item {
            padding: 1.75rem 1.5rem;
            border-right: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            gap: .3rem;
        }

        .stat-item:last-child {
            border-right: none;
        }

        .stat-num {
            font-family: 'Playfair Display', serif;
            font-size: clamp(1.6rem, 3vw, 2.4rem);
            font-weight: 700;
            color: var(--gold);
            line-height: 1;
        }

        .stat-label {
            font-family: 'DM Mono', monospace;
            font-size: .55rem;
            letter-spacing: .12em;
            text-transform: uppercase;
            color: var(--text3);
            transition: color .4s;
        }

        @media (max-width: 480px) {
            .stats-inner { grid-template-columns: repeat(2, 1fr); }
            .stat-item:nth-child(2) { border-right: none; }
        }

        /* ══ TOOLS GRID ══════════════════════════════ */
        .tools-grid {
            display: flex;
            flex-wrap: wrap;
            gap: .5rem;
        }

        .tool-chip {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: .45rem;
            padding: .8rem .6rem .7rem;
            border-radius: 10px;
            background: var(--bg2);
            border: 1px solid var(--rule);
            font-family: 'DM Mono', monospace;
            font-size: .6rem;
            font-weight: 600;
            letter-spacing: .06em;
            text-transform: uppercase;
            color: var(--text2);
            transition: border-color .25s, color .25s, transform .25s;
            min-width: 4rem;
            text-align: center;
            cursor: default;
        }

        .tool-chip:hover {
            border-color: rgba(255,255,255,.25);
            color: var(--text);
            transform: translateY(-2px);
        }

        .tool-icon {
            width: 28px;
            height: 28px;
            object-fit: contain;
            flex-shrink: 0;
            transition: filter .3s;
        }

        /* ══ WHAT I DO ═══════════════════════════════ */
        .services-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 1.5px;
            background: rgba(255, 255, 255, .04);
            border: 1px solid rgba(255, 255, 255, .04);
            border-radius: 16px;
            overflow: hidden;
            margin-top: .75rem;
        }

        .service-card {
            background: var(--svc-bg, var(--bg2));
            padding: 1.25rem 1.5rem .75rem;
            display: flex;
            flex-direction: column;
            gap: .75rem;
            transition: background .3s;
        }

        .service-card-body {
            display: flex;
            flex-direction: column;
            gap: .4rem;
        }

        .service-title-row {
            display: flex;
            align-items: center;
            gap: .65rem;
        }

        .service-title-row .service-icon {
            flex-shrink: 0;
        }

        .svc-toggle {
            cursor: pointer;
            user-select: none;
        }

        .svc-chevron {
            width: 16px;
            height: 16px;
            margin-left: auto;
            flex-shrink: 0;
            color: var(--svc-c, var(--text3));
            opacity: .5;
            transition: transform .3s cubic-bezier(0.23,1,0.32,1), opacity .2s;
        }

        .service-card.open .svc-chevron {
            transform: rotate(180deg);
            opacity: 1;
        }

        .svc-body {
            overflow: hidden;
            max-height: 0;
            transition: max-height .35s cubic-bezier(0.23,1,0.32,1), opacity .3s;
            opacity: 0;
        }

        .service-card.open .svc-body {
            max-height: 300px;
            opacity: 1;
        }

        .svc-body .service-desc {
            padding-top: .6rem;
        }

        .service-card:hover {
            background: color-mix(in srgb, var(--svc-bg, var(--bg3)) 70%, black);
        }

        .service-icon {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            position: relative;
            overflow: hidden;
            border: 1px solid transparent;
            transition: border-color .35s cubic-bezier(0.23, 1, 0.32, 1), box-shadow .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .service-icon::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.12) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
        }

        .svc-toggle:hover .service-icon::before { transform: translateX(100%); }

        .svc-toggle:hover .service-icon {
            border-color: color-mix(in srgb, var(--svc-c, #fff) 40%, transparent);
            box-shadow: 0 0 0 2px color-mix(in srgb, var(--svc-c, #fff) 12%, transparent), 0 0 10px color-mix(in srgb, var(--svc-c, #fff) 18%, transparent);
        }

        .si-g { background: var(--acc-dim); }
        .si-t { background: rgba(57, 255, 154, 0.08); }
        .si-b { background: rgba(59, 130, 246, 0.10); }

        .service-title {
            font-family: 'Playfair Display', serif;
            font-size: 1rem;
            font-weight: 400;
            line-height: 1.3;
            color: var(--text);
        }

        .service-desc {
            font-size: .82rem;
            line-height: 1.7;
            color: var(--text2);
        }

        .service-tags {
            display: flex;
            flex-wrap: wrap;
            gap: .35rem;
            margin-top: auto;
            padding-top: .4rem;
        }

        .stag {
            font-family: 'DM Mono', monospace;
            font-size: .55rem;
            letter-spacing: .08em;
            text-transform: uppercase;
            padding: .2rem .5rem;
            border-radius: 100px;
            border: 1px solid color-mix(in srgb, var(--svc-c, var(--border2)) 30%, transparent);
            color: var(--svc-c, var(--text3));
        }

        @media (max-width: 600px) {
            .services-grid { grid-template-columns: 1fr; }
        }

        /* ══ MASTHEAD ════════════════════════════════ */
        .masthead {
            --acc: #39FF9A;
            --acc2: #00D97E;
            --acc-dim: rgba(57, 255, 154, 0.08);
            --acc-b: rgba(57, 255, 154, 0.22);
            --gold: #39FF9A;
            display: flex;
            flex-direction: column;
            gap: 1rem;
            padding: 2rem 0 1rem;
        }

        .mast-top {
            display: flex;
            align-items: flex-start;
            justify-content: space-between;
            gap: 1rem;
            margin-bottom: 1.5rem;
        }

        .mast-kicker {
            font-family: 'DM Mono', monospace;
            font-size: .6rem;
            letter-spacing: .28em;
            text-transform: uppercase;
            color: var(--acc);
            display: flex;
            align-items: center;
            gap: .6rem;
            transition: color .4s;
        }

        .mast-kicker-logo::after {
            content: '';
            width: 20px;
            height: 1px;
            background: var(--acc);
            display: inline-block;
            vertical-align: middle;
            margin-left: 8px;
            transition: background .4s
        }

        .mast-domain {
            font-family: 'DM Mono', monospace;
            font-size: .58rem;
            letter-spacing: .14em;
            color: var(--text3);
            text-transform: uppercase;
            transition: color .4s;
        }

        .mast-hero {
            display: flex;
            align-items: center;
            gap: 1.5rem;
        }

        @media (max-width: 480px) {
            .mast-hero {
                flex-direction: column;
                align-items: center;
                gap: 1rem;
            }
            .mast-name {
                text-align: center;
            }
            .mast-kicker-logo svg {
                width: 42px !important;
            }
            .mast-loc {
                justify-content: center;
            }
            .mast-role {
                text-align: center;
            }
            .role-sep {
                display: none;
            }
            .role-item {
                display: block;
            }
        }

        .mast-name {
            font-family: 'Playfair Display', serif;
            font-size: clamp(2.6rem, 9vw, 5.5rem);
            font-weight: 900;
            line-height: .95;
            letter-spacing: -.02em;
            color: var(--text);
            transition: color .4s;
        }

        .mast-name em {
            font-style: italic;
            font-weight: 400;
            letter-spacing: .01em;
            color: var(--acc);
            transition: color .4s;
        }

        /* Avatar row */
        .mast-bottom {
            display: flex;
            align-items: center;
            gap: 1.25rem;
            margin-top: 1rem;
        }

        .avatar {
            width: 160px;
            height: 160px;
            border-radius: 50%;
            flex-shrink: 0;
            position: relative;
        }

        .avatar-ring {
            position: absolute;
            inset: -2px;
            border-radius: 50%;
            background: conic-gradient(var(--acc), var(--acc2), var(--bg3), var(--acc));
            animation: spin 6s linear infinite;
            transition: background .4s;
        }

        @keyframes spin {
            to {
                transform: rotate(360deg)
            }
        }

        .avatar-inner {
            position: relative;
            z-index: 1;
            width: 100%;
            height: 100%;
            border-radius: 50%;
            background: var(--bg3);
            border: 2px solid var(--bg);
            display: flex;
            align-items: center;
            justify-content: center;
            overflow: hidden;
            transition: background .4s, border-color .4s;
        }

        .avatar-init {
            font-family: 'DM Mono', monospace;
            font-size: .9rem;
            font-weight: 500;
            color: var(--acc);
            letter-spacing: .06em;
        }

        .mast-meta {
            flex: 1;
            min-width: 0
        }

        .mast-role {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: .82rem;
            font-weight: 500;
            color: var(--text);
            line-height: 1.5;
            transition: color .4s;
        }

        .mast-loc {
            display: flex;
            align-items: center;
            gap: .45rem;
            font-family: 'DM Mono', monospace;
            font-size: .58rem;
            letter-spacing: .12em;
            text-transform: uppercase;
            color: var(--text2);
            margin-top: .4rem;
            transition: color .4s;
        }

        .live {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background: var(--acc);
            box-shadow: 0 0 8px var(--acc-dim);
            animation: livepulse 2s ease-in-out infinite;
            transition: background .4s;
        }

        @keyframes livepulse {

            0%,
            100% {
                box-shadow: 0 0 6px var(--acc-b)
            }

            50% {
                box-shadow: 0 0 14px var(--acc-b), 0 0 26px var(--acc-dim)
            }
        }

        /* Bio */
        .mast-bio {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: .88rem;
            font-weight: 400;
            line-height: 1.75;
            color: var(--text);
            border-left: 2px solid var(--acc);
            padding-left: 1rem;
            transition: color .4s, border-color .4s;
        }

        .mast-bio strong {
            font-style: normal;
            font-weight: 700;
            color: var(--text);
            transition: color .4s;
        }

        /* ══ SECTION ═════════════════════════════════ */
        .section {
            margin-bottom: 2rem
        }

        .sec-head {
            display: flex;
            align-items: center;
            gap: .75rem;
            margin-bottom: 1rem;
        }

        .sec-label {
            font-family: 'DM Mono', monospace;
            font-size: .56rem;
            letter-spacing: .28em;
            text-transform: uppercase;
            color: var(--text3);
            white-space: nowrap;
            transition: color .4s;
        }

        .sec-rule {
            flex: 1;
            height: 1px;
            background: var(--rule);
            transition: background .4s
        }

        /* ══ WHO I AM CARDS ══════════════════════════ */
        .who-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: .6rem;
        }

        .who-card {
            background: var(--card);
            backdrop-filter: blur(12px);
            -webkit-backdrop-filter: blur(12px);
            border: 1px solid var(--border);
            border-radius: 20px;
            padding: 1.5rem 1rem 1.2rem;
            display: flex;
            flex-direction: column;
            align-items: center;
            text-align: center;
            gap: .8rem;
            transition: all .4s cubic-bezier(0.23, 1, 0.32, 1);
            position: relative;
            overflow: hidden;
        }

        .who-icon {
            width: 44px;
            height: 44px;
            border-radius: 12px;
            background: color-mix(in srgb, var(--wc, var(--acc)) 12%, transparent);
            border: 1px solid color-mix(in srgb, var(--wc, var(--acc)) 30%, transparent);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: background .3s, border-color .3s;
            margin-bottom: .2rem;
        }

        .who-icon svg {
            width: 20px;
            height: 20px;
            stroke: var(--wc, var(--acc));
        }

        .who-indicator {
            width: 100%;
            height: 2px;
            background: var(--border);
            margin-top: .5rem;
            position: relative;
            border-radius: 10px;
        }

        .who-indicator::after {
            content: '';
            position: absolute;
            top: 0; left: 0; height: 100%;
            width: var(--level, 70%);
            background: var(--wc, var(--acc));
            box-shadow: 0 0 8px color-mix(in srgb, var(--wc, var(--acc)) 30%, transparent);
            border-radius: 10px;
        }

        .who-level {
            font-family: 'DM Mono', monospace;
            font-size: .48rem;
            letter-spacing: .08em;
            text-transform: uppercase;
            color: var(--text3);
            margin-top: .3rem;
        }

        .who-initial {
            font-family: 'Playfair Display', serif;
            font-size: 1.9rem;
            font-weight: 900;
            font-style: italic;
            color: var(--acc);
            line-height: 1;
            transition: color .4s;
        }

        .who-title {
            font-size: .82rem;
            font-weight: 700;
            color: var(--text);
            letter-spacing: .02em;
            text-transform: uppercase;
            transition: color .4s;
        }

        .who-tags {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: .3rem;
        }

        .who-tag {
            font-family: 'DM Mono', monospace;
            font-size: .45rem;
            letter-spacing: .08em;
            text-transform: uppercase;
            color: var(--text2);
            background: var(--bg3);
            border: 1px solid var(--border);
            border-radius: 4px;
            padding: .2rem .4rem;
            transition: color .4s, background .4s, border-color .4s;
        }

        /* ══ STATS ROW ═══════════════════════════════ */
        .stats {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: .5rem;
        }

        .stat {
            background: var(--st-bg, #161616);
            border: 1px solid var(--st-b, rgba(255,255,255,0.08));
            border-radius: 12px;
            padding: 1rem;
            text-align: center;
            transition: background .4s, border-color .4s;
        }

        .stat-n {
            font-family: 'Playfair Display', serif;
            font-size: 1.7rem;
            font-weight: 900;
            color: var(--st-c, var(--acc));
            line-height: 1;
            transition: color .4s;
        }

        .stat-n em {
            font-style: normal;
            color: var(--st-c, var(--acc));
            transition: color .4s
        }

        .stat-l {
            font-family: 'DM Mono', monospace;
            font-size: .52rem;
            letter-spacing: .12em;
            text-transform: uppercase;
            color: var(--st-c, var(--text3));
            margin-top: .3rem;
            opacity: .7;
            transition: color .4s;
        }

        .stat-icon-wrap {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            margin: 0 auto .1rem;
            border: 1px solid var(--st-b, rgba(255,255,255,0.08));
            position: relative;
            overflow: hidden;
            transition: border-color .35s cubic-bezier(0.23, 1, 0.32, 1), box-shadow .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .stat-icon-wrap::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.12) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
        }

        .stat:hover .stat-icon-wrap::before { transform: translateX(100%); }

        .stat:hover .stat-icon-wrap {
            border-color: var(--st-c, rgba(255,255,255,0.3));
            box-shadow: 0 0 0 2px color-mix(in srgb, var(--st-c, #fff) 15%, transparent), 0 0 10px color-mix(in srgb, var(--st-c, #fff) 20%, transparent);
        }

        /* ══ LINK CARDS ══════════════════════════════ */
        .cards {
            display: flex;
            flex-direction: column;
            gap: .5rem
        }

        .lcard {
            display: flex;
            align-items: center;
            gap: 1rem;
            padding: .95rem 1.1rem;
            background: var(--card);
            border: 1px solid var(--border);
            border-radius: 14px;
            text-decoration: none;
            color: var(--text);
            transition: background .22s, border-color .22s, transform .22s, box-shadow .22s;
            position: relative;
            overflow: hidden;
            cursor: pointer;
        }

        .lcard::after {
            content: '';
            position: absolute;
            left: 0;
            top: 0;
            bottom: 0;
            width: 2px;
            background: var(--acc);
            transform: scaleY(0);
            transform-origin: bottom;
            transition: transform .3s ease;
        }

        .lcard:hover {
            background: var(--card2);
            border-color: var(--border2);
            transform: translateX(3px);
            box-shadow: 0 4px 20px var(--shadow);
        }

        .lcard:hover::after {
            transform: scaleY(1)
        }

        /* Head card */
        .lcard.head {
            border-color: var(--acc-b);
            padding: 1.15rem 1.1rem;
        }

        .lcard.head:hover {
            border-color: var(--acc);
            box-shadow: 0 4px 24px var(--shadow), 0 0 0 1px var(--acc-b)
        }

        /* Static (no hover translate) */
        .lcard.static {
            cursor: default
        }

        .lcard.static:hover {
            transform: none;
            background: var(--card);
            border-color: var(--border);
            box-shadow: none
        }

        .lcard.static:hover::after {
            transform: scaleY(0)
        }

        .lcard-icon {
            width: 44px;
            height: 44px;
            border-radius: 12px;
            background: var(--bg3);
            border: 1px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: all .4s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .lcard-icon svg {
            width: 18px;
            height: 18px;
            stroke-width: 2.2;
            transition: transform .4s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .lcard:hover .lcard-icon {
            background: var(--acc-dim);
            border-color: var(--acc);
            box-shadow: 0 0 0 3px var(--acc-dim), 0 0 12px var(--acc-b);
        }

        .lcard:hover .lcard-icon svg {
            stroke: var(--acc);
        }

        .lcard .lcard-icon {
            background: var(--acc-dim);
            border-color: var(--acc-b);
        }

        .lcard-body {
            flex: 1;
            min-width: 0
        }

        .lcard-eye {
            font-family: 'DM Mono', monospace;
            font-size: .52rem;
            letter-spacing: .14em;
            text-transform: uppercase;
            color: var(--text3);
            margin-bottom: .15rem;
            transition: color .4s;
        }

        .lcard.head .lcard-eye {
            color: var(--acc);
            opacity: .7
        }

        .lcard-title {
            font-size: .92rem;
            font-weight: 600;
            color: var(--text);
            line-height: 1.25;
            transition: color .4s;
        }

        .lcard-sub {
            font-size: .75rem;
            color: var(--text2);
            margin-top: .12rem;
            font-weight: 300;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            transition: color .4s;
        }

        .lcard-arr {
            width: 26px;
            height: 26px;
            border: 1px solid var(--border);
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            transition: border-color .25s, background .25s, transform .25s;
        }

        .lcard:hover .lcard-arr {
            border-color: var(--acc);
            background: var(--acc-dim);
            transform: rotate(45deg);
        }

        /* Event card */
        .lcard.event {
            border-color: rgba(245, 158, 11, .15);
            cursor: default
        }

        .lcard.event:hover {
            transform: none;
            background: var(--card);
            border-color: rgba(245, 158, 11, .15);
            box-shadow: none
        }

        .lcard.event:hover::after {
            transform: scaleY(0)
        }

        .lcard.event .lcard-arr {
            display: none
        }

        /* ══ SOCIALS ═════════════════════════════════ */
        .socials {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: .5rem;
        }

        .soc {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: .35rem;
            padding: .6rem .5rem;
            background: var(--card);
            border: 1px solid var(--border2);
            border-radius: 14px;
            text-decoration: none;
            color: var(--text2);
            transition: transform .3s, background .3s, border-color .3s, color .3s, box-shadow .3s;
            position: relative;
            overflow: hidden;
        }

        .soc:hover {
            background: linear-gradient(135deg, var(--sc) 0%, color-mix(in srgb, var(--sc) 70%, #000) 100%);
            border-color: var(--sc);
            color: #fff;
            transform: translateY(-2px);
        }

        .soc svg {
            width: 18px;
            height: 18px;
            position: relative;
            z-index: 2;
            fill: var(--text2);
            stroke: none;
            transition: fill .3s;
            flex-shrink: 0;
        }

        .soc:hover svg { fill: #fff; }

        .soc-n {
            font-family: 'DM Mono', monospace;
            font-size: .46rem;
            letter-spacing: .1em;
            text-transform: uppercase;
            font-weight: 600;
            position: relative;
            z-index: 2;
            color: var(--text2);
            text-align: center;
            line-height: 1;
            transition: color .3s;
        }

        .soc:hover .soc-n { color: #fff; }

        /* ══ SECTION HEADING ═════════════════════════ */
        .sec-title {
            font-family: 'DM Mono', monospace;
            font-size: .85rem;
            letter-spacing: .35em;
            text-transform: uppercase;
            color: var(--text3);
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 1.5rem;
            transition: color .4s;
            margin-bottom: .8rem;
            text-align: center;
            width: 100%;
        }

        .sec-title::before,
        .sec-title::after {
            content: '';
            flex: 1;
            height: 1px;
            background: var(--rule);
            transition: background .4s;
        }

        .sec-sub {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: .88rem;
            font-weight: 300;
            color: var(--text2);
            margin-top: .1rem;
            margin-bottom: 2rem;
            line-height: 1.6;
            text-align: center;
            max-width: 95%;
            margin-left: auto;
            margin-right: auto;
            transition: color .4s;
        }

        /* ══ SERVICES ════════════════════════════════ */
        .services {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
            gap: .5rem;
        }

        .srv {
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: .5rem;
            padding: .8rem .4rem .7rem;
            background: var(--srv-bg);
            backdrop-filter: blur(8px);
            -webkit-backdrop-filter: blur(8px);
            border: 1px solid color-mix(in srgb, var(--srv-c) 30%, transparent);
            border-radius: 14px;
            position: relative;
            overflow: hidden;
            transition: all .4s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .srv:hover {
            transform: translateY(-4px) scale(1.02);
            border-color: color-mix(in srgb, var(--srv-c) 60%, transparent);
            box-shadow: 0 10px 25px -10px var(--srv-c);
        }

        .srv::after {
            content: '';
            position: absolute;
            bottom: 0; left: 0; right: 0;
            height: 2px;
            background: var(--srv-c, var(--acc));
            transform: scaleX(0);
            transition: transform .3s ease;
            transform-origin: left;
        }

        .srv:hover::after {
            transform: scaleX(1);
        }

        .srv-icon {
            width: 36px;
            height: 36px;
            border-radius: 10px;
            background: color-mix(in srgb, var(--srv-c) 20%, transparent);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
            position: relative;
            overflow: hidden;
            border: 1px solid transparent;
            transition: border-color .35s cubic-bezier(0.23, 1, 0.32, 1), box-shadow .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .srv-icon::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.12) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
        }

        .srv:hover .srv-icon::before { transform: translateX(100%); }

        .srv:hover .srv-icon {
            border-color: color-mix(in srgb, var(--srv-c) 50%, transparent);
            box-shadow: 0 0 0 2px color-mix(in srgb, var(--srv-c) 12%, transparent), 0 0 10px color-mix(in srgb, var(--srv-c) 18%, transparent);
        }

        .srv-icon svg {
            width: 18px;
            height: 18px;
            stroke: var(--srv-c, var(--acc));
        }

        .srv-label {
            font-family: 'Plus Jakarta Sans', sans-serif;
            font-size: .6rem;
            font-weight: 600;
            color: #fff;
            text-align: center;
            line-height: 1.3;
        }

        .srv[data-target] { cursor: pointer; }

        /* ══ CONTACT LINK ════════════════════════════ */
        .contact-link {
            display: flex;
            align-items: center;
            gap: .75rem;
            padding: .7rem 1rem;
            background: color-mix(in srgb, var(--cl, var(--acc)) 12%, transparent);
            border: 1px solid color-mix(in srgb, var(--cl, var(--acc)) 30%, transparent);
            border-radius: 12px;
            text-decoration: none;
            color: var(--cl, var(--acc));
            font-size: .82rem;
            font-weight: 600;
            transition: background .22s, border-color .22s, transform .22s;
        }

        .contact-link:hover {
            background: color-mix(in srgb, var(--cl, var(--acc)) 22%, transparent);
            border-color: color-mix(in srgb, var(--cl, var(--acc)) 60%, transparent);
            transform: translateX(3px);
        }

        .contact-link svg {
            width: 16px;
            height: 16px;
            flex-shrink: 0;
        }

        .contact-link span {
            flex: 1;
        }

        .contact-sub {
            font-family: 'DM Mono', monospace;
            font-size: .52rem;
            letter-spacing: .08em;
            color: var(--text2);
            transition: color .4s;
        }

        /* ══ QUOTE ═══════════════════════════════════ */
        .quote-block {
            padding: 1.5rem 2rem;
            background: var(--acc-dim);
            border: 1px solid var(--acc-b);
            border-radius: 12px;
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: .5rem;
            position: relative;
            overflow: hidden;
            transition: background .4s, border-color .4s;
        }

        .quote-block::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.07) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
        }

        .quote-block:hover::before { transform: translateX(100%); }

        .quote-icon {
            color: rgba(255,255,255,0.5);
        }

        .quote-text {
            font-family: 'Playfair Display', serif;
            font-size: 1.3rem;
            font-style: italic;
            color: #F8F8F8;
            line-height: 1.75;
            color: var(--text2);
            transition: color .4s;
        }

        .quote-text em {
            font-style: normal;
            color: var(--text);
            font-weight: 700;
            transition: color .4s
        }

        /* ══ THEME TOGGLE ════════════════════════════ */
        .theme-btn {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 28px;
            height: 28px;
            border-radius: 8px;
            border: 1px solid var(--rule);
            background: var(--bg2);
            color: var(--text2);
            cursor: pointer;
            transition: background .3s, border-color .3s, color .3s, transform .2s;
            flex-shrink: 0;
        }

        .theme-btn:hover {
            border-color: var(--border2);
            color: var(--text);
            transform: scale(1.1);
        }

        .theme-btn svg { width: 14px; height: 14px; pointer-events: none; }
        .theme-btn .icon-moon { display: block; }
        .theme-btn .icon-sun  { display: none; }
        [data-theme="light"] .theme-btn .icon-moon { display: none; }
        [data-theme="light"] .theme-btn .icon-sun  { display: block; }

        /* ══ FOOTER ══════════════════════════════════ */
        .foot {
            padding-top: 1rem;
            border-top: 1px solid var(--rule);
            display: flex;
            justify-content: center;
            align-items: center;
            flex-wrap: wrap;
            gap: .5rem;
            transition: border-color .4s;
            margin-top: auto;
        }

        .foot-l,
        .foot-r {
            font-family: 'DM Mono', monospace;
            font-size: .55rem;
            letter-spacing: .1em;
            color: var(--text3);
            transition: color .4s;
        }

        .foot-r a {
            color: var(--acc);
            text-decoration: none;
            transition: color .4s
        }

        /* ══ REVEAL ══════════════════════════════════ */
        .r {
            opacity: 0;
            transform: translateY(28px);
            transition: opacity .7s cubic-bezier(0.22, 1, 0.36, 1), transform .7s cubic-bezier(0.22, 1, 0.36, 1);
        }

        .r.from-left  { transform: translateX(-32px); }
        .r.from-right { transform: translateX(32px); }
        .r.from-up    { transform: translateY(-20px); }
        .r.scale-in   { transform: scale(0.94); }

        .r.in {
            opacity: 1;
            transform: translateY(0) translateX(0) scale(1);
        }

        /* stagger children inside a revealed parent */
        .r-group > * {
            opacity: 0;
            transform: translateY(22px);
            transition: opacity .6s cubic-bezier(0.22, 1, 0.36, 1), transform .6s cubic-bezier(0.22, 1, 0.36, 1);
        }

        .r-group.in > *:nth-child(1)  { transition-delay: .05s; }
        .r-group.in > *:nth-child(2)  { transition-delay: .13s; }
        .r-group.in > *:nth-child(3)  { transition-delay: .21s; }
        .r-group.in > *:nth-child(4)  { transition-delay: .29s; }
        .r-group.in > *:nth-child(5)  { transition-delay: .37s; }
        .r-group.in > *:nth-child(6)  { transition-delay: .45s; }
        .r-group.in > *:nth-child(7)  { transition-delay: .53s; }
        .r-group.in > *:nth-child(8)  { transition-delay: .61s; }

        .r-group.in > * {
            opacity: 1;
            transform: translateY(0);
        }

        /* ══ AVATAR LIGHTBOX ═════════════════════════ */
        .av-lightbox {
            position: fixed;
            inset: 0;
            z-index: 10000;
            display: flex;
            align-items: center;
            justify-content: center;
            opacity: 0;
            visibility: hidden;
            transition: opacity .3s ease, visibility .3s ease;
        }

        .av-lightbox.open {
            opacity: 1;
            visibility: visible;
        }

        .av-backdrop {
            position: absolute;
            inset: 0;
            background: rgba(0,0,0,.85);
            backdrop-filter: blur(6px);
        }

        .av-content {
            position: relative;
            z-index: 1;
            transform: scale(.92);
            transition: transform .3s cubic-bezier(0.22,1,0.36,1);
        }

        .av-lightbox.open .av-content {
            transform: scale(1);
        }

        .av-img {
            display: block;
            width: min(80vw, 420px);
            height: min(80vw, 420px);
            object-fit: cover;
            border-radius: 16px;
            border: 2px solid rgba(57,255,154,0.4);
            box-shadow: 0 0 40px rgba(57,255,154,0.15);
            user-select: none;
            -webkit-user-drag: none;
            touch-action: none;
        }

        .av-close {
            position: absolute;
            top: -14px;
            right: -14px;
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background: #1a1a1a;
            border: 1px solid rgba(255,255,255,0.15);
            color: #fff;
            font-size: 1.2rem;
            line-height: 1;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: background .2s;
        }

        .av-close:hover { background: #333; }

        .avatar-clickable:hover .avatar-ring {
            opacity: 1;
        }

        /* ── DPN CTA ─────────────────────────────────────────────────────── */
        /* dark mode (default) */
        .dpn-cta {
            text-align: center;
            padding: 2rem 1.5rem;
            border-radius: 16px;
            border: 1px solid rgba(26,111,212,0.5);
            background: linear-gradient(135deg, rgba(26,111,212,0.45) 0%, rgba(13,62,135,0.4) 100%);
            position: relative;
            overflow: hidden;
            transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
        }

        .dpn-cta::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.07) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
        }

        .dpn-cta:hover::before { transform: translateX(100%); }

        .dpn-cta:hover {
            transform: translateY(-3px);
            box-shadow: 0 8px 32px rgba(26,111,212,0.35);
            border-color: rgba(26,111,212,0.8);
        }

        .dpn-cta:active {
            transform: translateY(0);
            box-shadow: none;
        }

        .dpn-cta-logo {
            display: block;
            max-width: 200px;
            height: auto;
            margin: 0 auto .85rem;
        }
        .dpn-cta-logo--dark  { display: block; }
        .dpn-cta-logo--light { display: none; }

        .dpn-cta-heading {
            font-family: 'Playfair Display', serif;
            font-size: 1.45rem;
            font-weight: 700;
            color: #F8F8F8;
            margin-bottom: .6rem;
        }

        .dpn-cta-sub {
            font-size: .88rem;
            line-height: 1.7;
            color: rgba(255,255,255,.7);
            max-width: 480px;
            margin: 0 auto 1.25rem;
        }

        .dpn-cta-btn {
            display: inline-flex;
            align-items: center;
            gap: .5rem;
            padding: .65rem 1.4rem;
            background: #F5B800;
            color: #1A0E00;
            font-family: 'DM Mono', monospace;
            font-size: .78rem;
            font-weight: 500;
            letter-spacing: .06em;
            text-transform: uppercase;
            text-decoration: none;
            border-radius: 8px;
            transition: opacity .35s cubic-bezier(0.23, 1, 0.32, 1), transform .35s cubic-bezier(0.23, 1, 0.32, 1), box-shadow .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .dpn-cta-btn:hover {
            opacity: .9;
            transform: translateY(-2px);
            box-shadow: 0 4px 10px rgba(245,184,0,0.2);
        }

        .dpn-cta-btn:active {
            transform: translateY(1px);
            box-shadow: none;
        }

        .dpn-cta-btn svg {
            transition: transform .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .dpn-cta-btn:hover svg {
            transform: translate(2px, -2px);
        }

        .contact-send-btn {
            display: inline-flex;
            align-items: center;
            gap: .4rem;
            padding: .4rem .9rem;
            background: #3B82F6;
            color: #fff;
            font-family: 'DM Mono', monospace;
            font-size: .6rem;
            font-weight: 500;
            letter-spacing: .08em;
            text-transform: uppercase;
            border-radius: 999px;
            transition: transform .35s cubic-bezier(0.23, 1, 0.32, 1), box-shadow .35s cubic-bezier(0.23, 1, 0.32, 1), opacity .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .contact-card::before {
            content: '';
            position: absolute;
            inset: 0;
            background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.07) 50%, transparent 100%);
            transform: translateX(-100%);
            transition: transform .55s ease;
            pointer-events: none;
            z-index: 1;
        }

        .contact-card:hover::before { transform: translateX(100%); }

        .contact-card:hover .contact-send-btn {
            background: #1D6EE8;
            color: #fff;
        }

        .contact-card:active .contact-send-btn {
            background: #1558C0;
            color: #fff;
        }

        .contact-send-btn svg {
            transition: transform .35s cubic-bezier(0.23, 1, 0.32, 1);
        }

        .contact-card:hover .contact-send-btn svg {
            transform: translate(2px, -2px);
        }

        [data-theme="light"] .contact-send-btn {
            background: #1A0E00;
            color: #F5B800;
        }

        [data-theme="light"] .contact-card:hover .contact-send-btn {
            background: #3B82F6;
            color: #fff;
        }

        /* light mode overrides */
        [data-theme="light"] .dpn-cta {
            background: linear-gradient(135deg, #F5B800 0%, #E0A800 100%);
            border-color: rgba(180,130,0,0.4);
        }

        [data-theme="light"] .dpn-cta-logo--dark  { display: none; }
        [data-theme="light"] .dpn-cta-logo--light { display: block; }

        [data-theme="light"] .dpn-cta-heading { color: #0D0D0D; }

        [data-theme="light"] .dpn-cta-sub { color: rgba(0,0,0,.65); }

        [data-theme="light"] .dpn-cta-btn {
            background: #1A6FD4;
            color: #ffffff;
        }

        [data-theme="light"] .dpn-cta-btn:hover {
            box-shadow: 0 4px 10px rgba(26,111,212,0.2);
        }

        [data-theme="light"] .dpn-cta:hover {
            box-shadow: 0 8px 32px rgba(180,130,0,0.3);
            border-color: rgba(180,130,0,0.6);
        }
