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

    :root {
        --bg:       #111009;
        --surface:  #1a1814;
        --border:   rgba(240, 236, 224, 0.08);
        --cream:    #f0ece3;
        --muted:    rgba(240, 236, 224, 0.46);
        --sub:      rgba(240, 236, 224, 0.52);
        --dimmed:   rgba(240, 236, 224, 0.62);
        --rust:     #d4500a;
        --rust-dim: rgba(212, 80, 10, 0.15);
    }

    html { background: var(--bg); scroll-behavior: smooth; }

    body {
        font-family: 'Epilogue', sans-serif;
        background: var(--bg);
        color: var(--cream);
        overflow-x: hidden;
        -webkit-font-smoothing: antialiased;
    }

    /* subtle grain */
    body::before {
        content: '';
        position: fixed;
        inset: 0;
        background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
        background-size: 200px 200px;
        opacity: 0.028;
        pointer-events: none;
        z-index: 9997;
    }

    /* ── CURTAIN ── */
    #curtain {
        position: fixed; inset: 0; z-index: 9999;
        background: var(--bg);
        display: flex; flex-direction: column;
        align-items: center; justify-content: center; gap: 0;
        will-change: transform;
        /* FIX: no animation here — triggered via JS class to avoid premature animationend */
    }
    #curtain.rising {
        animation: curtain-rise 1s cubic-bezier(0.76, 0, 0.24, 1) forwards;
    }
    @keyframes curtain-rise {
        0%   { transform: translateY(0); }
        100% { transform: translateY(-100%); }
    }

    .c-line { overflow: hidden; }

    .c-name {
        font-family: 'Fraunces', serif;
        font-size: clamp(3.8rem, 14vw, 11rem);
        font-weight: 400;
        letter-spacing: -0.03em;
        color: var(--cream);
        transform: translateY(105%);
        animation: up 0.75s cubic-bezier(0.16, 1, 0.3, 1) 0.1s forwards;
        line-height: 1;
    }
    .c-rule {
        width: 0; height: 1px;
        background: var(--border);
        margin: 22px 0 20px;
        animation: rule-draw 0.65s ease-out 0.4s forwards;
    }
    @keyframes rule-draw { to { width: clamp(140px, 28vw, 340px); } }

    .c-sub {
        font-family: 'Syne', sans-serif;
        font-size: clamp(0.6rem, 1.3vw, 0.75rem);
        letter-spacing: 0.2em;
        text-transform: uppercase;
        color: var(--muted);
        transform: translateY(100%);
        animation: up 0.6s cubic-bezier(0.16, 1, 0.3, 1) 0.42s forwards;
    }
    @keyframes up { to { transform: translateY(0); } }

    /* ── SITE ── */
    #site { opacity: 0; transition: opacity 0.7s ease; }
    #site.revealed { opacity: 1; }

    /* ── NAV ── */
    header {
        position: fixed; top: 0; left: 0; right: 0;
        z-index: 100;
        padding: 0 clamp(1.5rem, 5vw, 3.5rem);
        height: 60px;
        display: flex; align-items: center; justify-content: space-between;
        background: rgba(17,16,9,0.85);
        backdrop-filter: blur(16px);
        border-bottom: 1px solid var(--border);
        /* FIX: start hidden, JS adds revealed class which triggers animation */
        transform: translateY(-100%);
        transition: none;
    }
    #site.revealed header {
        animation: header-in 0.65s cubic-bezier(0.16,1,0.3,1) 0.15s both;
    }
    @keyframes header-in {
        from { transform: translateY(-100%); }
        to   { transform: translateY(0); }
    }

    .nav-logo {
        font-family: 'Fraunces', serif;
        font-size: 1.1rem; font-weight: 400; letter-spacing: -0.01em;
        color: var(--cream); text-decoration: none;
    }
    .nav-links { display: flex; align-items: center; gap: 2.5rem; list-style: none; }
    .nav-links a {
        font-family: 'Syne', sans-serif;
        font-size: 0.68rem; font-weight: 500;
        letter-spacing: 0.13em; text-transform: uppercase;
        color: var(--muted); text-decoration: none;
        transition: color 0.2s;
    }
    .nav-links a:hover { color: var(--cream); }

    .nav-hire {
        font-family: 'Syne', sans-serif;
        font-size: 0.68rem; font-weight: 600;
        letter-spacing: 0.1em; text-transform: uppercase;
        color: var(--rust);
        border: 1px solid rgba(212,80,10,0.4);
        padding: 7px 16px; border-radius: 4px;
        text-decoration: none;
        transition: background 0.2s, color 0.2s;
    }
    .nav-hire:hover { background: var(--rust); color: #fff; }

    .nav-mobile-btn {
        display: none; background: none; border: none;
        color: var(--muted); cursor: pointer; padding: 4px;
    }

    /* FIX: added z-index so menu renders above all page content */
    #mobile-menu {
        display: none; position: fixed;
        top: 60px; left: 0; right: 0;
        z-index: 99;
        background: rgba(17,16,9,0.98);
        border-bottom: 1px solid var(--border);
        padding: 1.5rem clamp(1.5rem, 5vw, 3.5rem);
        flex-direction: column; gap: 1.2rem;
        backdrop-filter: blur(16px);
    }
    #mobile-menu.open { display: flex; }
    #mobile-menu a {
        font-family: 'Syne', sans-serif; font-size: 0.8rem;
        letter-spacing: 0.12em; text-transform: uppercase;
        color: var(--muted); text-decoration: none; transition: color 0.2s;
    }
    #mobile-menu a:hover { color: var(--cream); }

    /* ── LAYOUT ── */
    .wrap { max-width: 1020px; margin: 0 auto; padding: 0 clamp(1.5rem, 5vw, 3.5rem); }
    .divider { border: none; border-top: 1px solid var(--border); }

    /* ── SCROLL REVEAL ── */
    .reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s ease, transform 0.7s ease; }
    .reveal.in { opacity: 1; transform: translateY(0); }

    /* ── SECTION CHROME ── */
    .section-label {
        font-family: 'Syne', sans-serif;
        font-size: 0.66rem; font-weight: 500;
        letter-spacing: 0.2em; text-transform: uppercase;
        color: var(--rust); margin-bottom: 1rem;
        display: flex; align-items: center; gap: 12px;
    }
    .section-label::after {
        content: ''; flex: 0 0 44px;
        height: 1px; background: var(--rust); opacity: 0.4;
    }
    .section-title {
        font-family: 'Fraunces', serif;
        font-size: clamp(2.2rem, 4.5vw, 3.2rem);
        font-weight: 400; letter-spacing: -0.022em; line-height: 1.08;
        color: var(--cream); margin-bottom: 3.5rem;
    }
    .section-title em { font-style: italic; font-weight: 300; color: var(--muted); }

    /* ── HERO ── */
    #hero { padding: 140px 0 100px; min-height: 100svh; display: flex; flex-direction: column; justify-content: center; }

    .hero-eyebrow {
        display: flex; align-items: center; gap: 10px;
        margin-bottom: 2.5rem; opacity: 0; transform: translateY(14px);
    }
    #site.revealed .hero-eyebrow { animation: fade-up 0.7s ease 0.5s both; }

    .avail-dot {
        width: 7px; height: 7px;
        background: #3d8c4b; border-radius: 50%; flex-shrink: 0;
    }
    .hero-eyebrow span {
        font-family: 'Syne', sans-serif;
        font-size: 0.7rem; letter-spacing: 0.13em; text-transform: uppercase;
        color: var(--muted);
    }

    .hero-headline {
        font-family: 'Fraunces', serif;
        font-size: clamp(3.2rem, 8.5vw, 6.8rem);
        font-weight: 400; letter-spacing: -0.028em; line-height: 1.03;
        color: var(--cream); margin-bottom: 2.2rem;
    }
    .hero-headline em { font-style: italic; font-weight: 300; color: var(--muted); }

    .hl { display: block; overflow: hidden; }
    .hl span { display: block; transform: translateY(110%); }
    #site.revealed .hl:nth-child(1) span { animation: up 0.75s cubic-bezier(0.16,1,0.3,1) 0.55s both; }
    #site.revealed .hl:nth-child(2) span { animation: up 0.75s cubic-bezier(0.16,1,0.3,1) 0.67s both; }
    #site.revealed .hl:nth-child(3) span { animation: up 0.75s cubic-bezier(0.16,1,0.3,1) 0.79s both; }

    .hero-body {
        font-size: clamp(1rem, 1.5vw, 1.1rem); font-weight: 300;
        line-height: 1.82; color: var(--dimmed);
        max-width: 520px; margin-bottom: 2.8rem;
        opacity: 0;
    }
    #site.revealed .hero-body { animation: fade-up 0.7s ease 0.95s both; }

    .hero-cta { display: flex; flex-wrap: wrap; align-items: center; gap: 1.5rem; opacity: 0; }
    #site.revealed .hero-cta { animation: fade-up 0.7s ease 1.1s both; }

    @keyframes fade-up {
        from { opacity: 0; transform: translateY(14px); }
        to   { opacity: 1; transform: translateY(0); }
    }

    .btn-primary {
        font-family: 'Syne', sans-serif;
        font-size: 0.7rem; font-weight: 600;
        letter-spacing: 0.1em; text-transform: uppercase;
        color: var(--bg); background: var(--cream);
        padding: 12px 22px; border-radius: 4px;
        text-decoration: none;
        display: inline-flex; align-items: center; gap: 8px;
        transition: opacity 0.2s, transform 0.2s;
    }
    .btn-primary:hover { opacity: 0.85; transform: translateY(-1px); }

    .btn-ghost {
        font-family: 'Syne', sans-serif;
        font-size: 0.7rem; font-weight: 500;
        letter-spacing: 0.13em; text-transform: uppercase;
        color: var(--muted); text-decoration: none;
        border-bottom: 1px solid var(--border); padding-bottom: 2px;
        transition: color 0.2s, border-color 0.2s;
    }
    .btn-ghost:hover { color: var(--cream); border-color: rgba(240,236,224,0.3); }

    /* ── ABOUT ── */
    #about { padding: 7rem 0; }
    .about-grid { display: grid; grid-template-columns: 1fr 270px; gap: 4rem; align-items: start; }
    .about-text p { font-size: 1rem; font-weight: 300; line-height: 1.88; color: var(--dimmed); margin-bottom: 1.25rem; }
    .about-text p:last-child { margin-bottom: 0; }
    .about-text strong { color: var(--cream); font-weight: 500; }
    .about-meta { border-left: 1px solid var(--border); padding-left: 2rem; }
    .meta-item { padding: 1.1rem 0; border-bottom: 1px solid var(--border); }
    .meta-item:last-child { border-bottom: none; }
    .meta-label {
        font-family: 'Syne', sans-serif; font-size: 0.62rem;
        letter-spacing: 0.18em; text-transform: uppercase;
        color: var(--muted); margin-bottom: 5px;
    }
    .meta-value { font-size: 0.92rem; font-weight: 400; color: var(--cream); }
    .meta-note { font-size: 0.9rem; color: var(--muted); margin-top: 2px; }

    /* ── STACK ── */
    #stack { padding: 7rem 0; }

    .stack-table { width: 100%; border-collapse: collapse; }
    .stack-table tr { border-bottom: 1px solid var(--border); }
    .stack-table tr:first-child { border-top: 1px solid var(--border); }
    .stack-cat-cell {
        font-family: 'Syne', sans-serif;
        font-size: 0.64rem; font-weight: 600;
        letter-spacing: 0.2em; text-transform: uppercase;
        color: var(--muted);
        padding: 1.6rem 2rem 1.6rem 0;
        vertical-align: top;
        white-space: nowrap;
        width: 130px;
    }
    .stack-pills-cell { padding: 1.4rem 0; vertical-align: middle; }
    .stack-pills { display: flex; flex-wrap: wrap; gap: 8px; }

    .pill {
        font-family: 'Epilogue', sans-serif;
        font-size: 0.9rem; font-weight: 400;
        color: var(--dimmed);
        padding: 6px 16px;
        border: 1px solid var(--border);
        border-radius: 999px;
        background: transparent;
        cursor: default;
        transition: color 0.2s, border-color 0.2s, background 0.2s;
        white-space: nowrap;
        line-height: 1.4;
    }
    .pill:hover {
        color: var(--cream);
        border-color: rgba(240,236,224,0.25);
        background: rgba(240,236,224,0.04);
    }
    .pill-cert {
        color: var(--rust);
        border-color: rgba(212,80,10,0.35);
        background: rgba(212,80,10,0.07);
        font-weight: 500;
    }
    .pill-cert:hover {
        color: #e06030;
        border-color: rgba(212,80,10,0.55);
        background: rgba(212,80,10,0.12);
    }

    @media (max-width: 600px) {
        .stack-table, .stack-table tbody,
        .stack-table tr, .stack-cat-cell, .stack-pills-cell { display: block; }
        .stack-cat-cell { padding: 1.4rem 0 0.5rem; }
        .stack-pills-cell { padding: 0 0 1.4rem; }
    }

    /* ── PROJECTS ── */
    #projects { padding: 7rem 0; }
    .projects-hd { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 3rem; flex-wrap: wrap; gap: 1rem; }
    .projects-hd h2 { margin-bottom: 0; }

    .project-card {
        border: 1px solid var(--border);
        border-radius: 8px; background: var(--surface);
        padding: clamp(1.5rem, 4vw, 2.4rem);
        margin-bottom: 1.2rem; position: relative; overflow: hidden;
        transition: border-color 0.3s, transform 0.3s;
    }
    .project-card::before {
        content: ''; position: absolute;
        left: 0; top: 0; bottom: 0; width: 2px;
        background: var(--rust);
        transform: scaleY(0); transform-origin: bottom;
        transition: transform 0.35s cubic-bezier(0.16,1,0.3,1);
    }
    .project-card:hover { border-color: rgba(240,236,224,0.13); transform: translateY(-2px); }
    .project-card:hover::before { transform: scaleY(1); }

    .project-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
    .project-title {
        font-family: 'Fraunces', serif;
        font-size: clamp(1.15rem, 2.3vw, 1.5rem);
        font-weight: 400; letter-spacing: -0.01em; line-height: 1.2;
        color: var(--cream);
    }
    .project-badge {
        font-family: 'Syne', sans-serif; font-size: 0.58rem; font-weight: 600;
        letter-spacing: 0.12em; text-transform: uppercase;
        padding: 4px 10px; border-radius: 40px; white-space: nowrap; flex-shrink: 0;
    }
    .badge-rust  { background: var(--rust-dim); color: #e07042; border: 1px solid rgba(212,80,10,0.25); }
    .badge-teal  { background: rgba(20,120,100,0.12); color: #4aad95; border: 1px solid rgba(20,120,100,0.25); }
    .badge-stone { background: rgba(240,236,224,0.05); color: var(--muted); border: 1px solid var(--border); }

    .project-body { font-size: 1rem; font-weight: 300; line-height: 1.82; color: var(--dimmed); max-width: 610px; margin-bottom: 1.1rem; }
    .project-body strong { color: var(--cream); font-weight: 500; }
    .project-stack { font-family: 'Epilogue', sans-serif; font-size: 0.93rem; font-weight: 300; color: var(--dimmed); margin-bottom: 1.4rem; letter-spacing: 0.01em; }
    .project-links { display: flex; gap: 1.5rem; }
    .project-links a {
        font-family: 'Syne', sans-serif; font-size: 0.7rem; font-weight: 500;
        letter-spacing: 0.1em; text-transform: uppercase;
        color: var(--muted); text-decoration: none;
        border-bottom: 1px solid var(--border); padding-bottom: 2px;
        transition: color 0.2s, border-color 0.2s;
    }
    .project-links a:hover { color: var(--cream); border-color: rgba(240,236,224,0.3); }

    /* ── EXPERIENCE ── */
    #experience { padding: 7rem 0; }
    .exp-item {
        display: grid; grid-template-columns: 1fr auto; gap: 2rem;
        padding: 2.2rem 0 2.2rem 1.8rem;
        border-left: 1px solid var(--border);
        position: relative; transition: border-color 0.2s;
    }
    .exp-item::before {
        content: ''; position: absolute; left: -4.5px; top: 2.7rem;
        width: 8px; height: 8px; border-radius: 50%;
        background: var(--surface); border: 1px solid var(--border);
        transition: background 0.2s, border-color 0.2s;
    }
    .exp-item:hover { border-left-color: var(--rust); }
    .exp-item:hover::before { background: var(--rust); border-color: var(--rust); }

    .exp-role { font-family: 'Fraunces', serif; font-size: 1.3rem; font-weight: 400; color: var(--cream); letter-spacing: -0.01em; margin-bottom: 10px; }
    .exp-org { font-family: 'Syne', sans-serif; font-size: 0.76rem; letter-spacing: 0.11em; text-transform: uppercase; color: var(--rust); margin-bottom: 1.2rem; }
    .exp-desc { font-size: 1rem; font-weight: 300; line-height: 1.82; color: var(--dimmed); max-width: 520px; margin-bottom: 1rem; }
    .exp-badges { display: flex; flex-wrap: wrap; gap: 6px; }
    .exp-badge {
        font-family: 'Syne', sans-serif; font-size: 0.6rem; font-weight: 600;
        letter-spacing: 0.1em; text-transform: uppercase;
        padding: 4px 9px; border-radius: 3px;
        border: 1px solid var(--border); color: var(--sub);
    }
    .exp-badge.active { border-color: rgba(212,80,10,0.3); color: #e07042; background: var(--rust-dim); }
    .exp-date { font-family: 'Syne', sans-serif; font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sub); white-space: nowrap; text-align: right; padding-top: 4px; line-height: 1.7; }

    /* ── ACTIVITY ── */
    #activity { padding: 7rem 0; }
    .chart-wrap { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; background: var(--surface); padding: 2rem; }
    .chart-wrap img { width: 100%; height: auto; filter: saturate(0.8) brightness(0.85); transition: filter 0.3s; }
    .chart-wrap:hover img { filter: saturate(1.1) brightness(1); }

    /* ── STATS STRIP ── */
    .stats-strip {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        border-top: 1px solid var(--border);
        border-bottom: 1px solid var(--border);
    }
    .stat-cell {
        padding: 2rem clamp(1.5rem, 5vw, 3.5rem);
        border-right: 1px solid var(--border);
        position: relative;
    }
    .stat-cell:last-child { border-right: none; }
    .stat-num {
        font-family: 'Fraunces', serif;
        font-size: clamp(2rem, 4vw, 3rem);
        font-weight: 400;
        letter-spacing: -0.03em;
        color: var(--cream);
        line-height: 1;
        margin-bottom: 6px;
    }
    .stat-num .accent { color: var(--rust); }
    .stat-desc {
        font-family: 'Syne', sans-serif;
        font-size: 0.74rem;
        letter-spacing: 0.14em;
        text-transform: uppercase;
        color: var(--dimmed);
    }
    @media (max-width: 600px) {
        .stats-strip { grid-template-columns: 1fr 1fr; }
        .stat-cell:nth-child(2) { border-right: none; }
        .stat-cell:nth-child(3) { border-top: 1px solid var(--border); }
        .stat-cell:nth-child(4) { border-top: 1px solid var(--border); border-right: none; }
    }

    /* ── PROJECT CARD ENHANCEMENTS ── */
    .proj-num {
        font-family: 'Fraunces', serif;
        font-size: clamp(5rem, 12vw, 9rem);
        font-weight: 400;
        color: var(--cream);
        opacity: 0.04;
        position: absolute;
        right: 1.5rem;
        top: 50%;
        transform: translateY(-50%);
        line-height: 1;
        pointer-events: none;
        user-select: none;
        transition: opacity 0.3s;
    }
    .project-card:hover .proj-num { opacity: 0.07; }
    .proj-tag-line {
        font-family: 'Fraunces', serif;
        font-style: italic;
        font-size: clamp(0.92rem, 1.6vw, 1.06rem);
        color: var(--sub);
        margin-top: 0.3rem;
        margin-bottom: 1.1rem;
        font-weight: 300;
    }

    /* ── BLOG ── */
    #writing { padding: 7rem 0; }
    .blog-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 1.2rem;
    }
    .blog-card {
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        padding: 1.8rem;
        display: flex; flex-direction: column;
        position: relative; overflow: hidden;
        transition: border-color 0.25s, transform 0.25s;
        text-decoration: none;
    }
    .blog-card::after {
        content: ''; position: absolute;
        bottom: 0; left: 0; right: 0; height: 2px;
        background: var(--rust);
        transform: scaleX(0); transform-origin: left;
        transition: transform 0.35s cubic-bezier(0.16,1,0.3,1);
    }
    .blog-card:hover { border-color: rgba(240,236,224,0.14); transform: translateY(-3px); }
    .blog-card:hover::after { transform: scaleX(1); }
    .blog-tag {
        font-family: 'Syne', sans-serif; font-size: 0.58rem; font-weight: 600;
        letter-spacing: 0.14em; text-transform: uppercase;
        color: var(--rust); margin-bottom: 1rem;
    }
    .blog-title {
        font-family: 'Fraunces', serif;
        font-size: clamp(1rem, 1.8vw, 1.2rem);
        font-weight: 400; letter-spacing: -0.01em; line-height: 1.3;
        color: var(--cream); margin-bottom: 0.8rem; flex: 1;
    }
    .blog-excerpt {
        font-size: 0.95rem; font-weight: 300; line-height: 1.75;
        color: var(--dimmed); margin-bottom: 1.4rem;
    }
    .blog-meta {
        display: flex; align-items: center; justify-content: space-between;
        font-family: 'Syne', sans-serif; font-size: 0.7rem;
        letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted);
    }
    .blog-arrow { font-size: 0.9rem; transition: transform 0.2s, color 0.2s; color: var(--muted); }
    .blog-card:hover .blog-arrow { transform: translate(3px,-3px); color: var(--rust); }
    @media (max-width: 768px) { .blog-grid { grid-template-columns: 1fr; } }

    /* ── CONTACT ── */
    #contact { padding: 8rem 0; }
    .contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: end; }
    .contact-headline {
        font-family: 'Fraunces', serif;
        font-size: clamp(2.8rem, 6vw, 4.6rem);
        font-weight: 400; letter-spacing: -0.025em; line-height: 1.05;
        color: var(--cream);
    }
    .contact-headline em { font-style: italic; font-weight: 300; color: var(--muted); }
    .contact-right p { font-size: 0.93rem; font-weight: 300; line-height: 1.82; color: var(--dimmed); margin-bottom: 2.5rem; }
    .clink {
        display: flex; align-items: center; justify-content: space-between;
        padding: 14px 0; border-bottom: 1px solid var(--border);
        text-decoration: none; color: var(--dimmed);
        font-size: 0.88rem; gap: 1rem;
        transition: color 0.2s, border-color 0.2s;
    }
    .clink:hover { color: var(--cream); border-color: rgba(240,236,224,0.18); }
    .clink .arr { font-size: 1rem; transition: transform 0.2s; }
    .clink:hover .arr { transform: translate(3px,-3px); }

    /* ── FOOTER ── */
    footer { border-top: 1px solid var(--border); padding: 1.8rem 0; }
    .footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
    .footer-inner p { font-family: 'Syne', sans-serif; font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); }

    /* ── RESPONSIVE ── */
    @media (max-width: 768px) {
        .nav-links, .nav-hire { display: none; }
        .nav-mobile-btn { display: block; }
        .about-grid { grid-template-columns: 1fr; }
        .about-meta { border-left: none; border-top: 1px solid var(--border); padding-left: 0; padding-top: 2rem; }
        .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
        .exp-item { grid-template-columns: 1fr; }
        .exp-date { text-align: left; }
        .stack-row { flex-direction: column; gap: 1rem; }
    }