:root{
    --bg:#F5F1EA;
    --text:#1B1B1B;
    --ink:#1F2D25;
    --muted:#777;
    --soft:#555;
    --surface:#FFFDF8;
    --line:rgba(0,0,0,0.08);
    --nav-bg:rgba(245,241,234,0.68);
    --shadow:0 24px 70px rgba(31,45,37,0.08);
    --radius:18px;
    --radius-small:8px;
}

html{
    scroll-behavior:smooth;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Poppins', sans-serif;
}

body{
    background:var(--bg);
    color:var(--text);
    overflow-x:hidden;
}

a{
    color:inherit;
}

/* INTRO SCREEN */

.intro-screen{
    position:fixed;
    inset:0;
    width:100%;
    height:100vh;
    background:
        radial-gradient(circle at 50% 42%, rgba(31,45,37,0.08), transparent 32%),
        var(--bg);
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:99999;
    transition:1.2s ease;
    overflow:hidden;
}

.intro-screen::before{
    content:"";
    position:absolute;
    inset:34px;
    border:1px solid rgba(31,45,37,0.08);
    pointer-events:none;
}

.intro-content{
    position:relative;
    text-align:center;
    z-index:1;
}

.intro-kicker{
    margin-bottom:24px;
}

#intro-clock{
    font-size:clamp(70px,16vw,220px);
    letter-spacing:-4px;
    color:#1f1919;
    font-weight:700;
    margin-bottom:20px;
    transition:2s ease;
}

.intro-content p{
    font-size:14px;
    letter-spacing:6px;
    text-transform:uppercase;
    color:var(--muted);
}

.main-website{
    opacity:0;
    transform:translateY(80px);
    filter:blur(10px);
    transition:opacity 1.4s ease, transform 1.4s ease, filter 1.4s ease;
}

.main-website.show{
    opacity:1;
    transform:translateY(0);
    filter:blur(0);
}

.intro-screen.hide{
    opacity:0;
    transform:translateY(-80px) scale(1.02);
    filter:blur(10px);
    pointer-events:none;
}

/* NAVBAR */

nav{
    width:100%;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:30px;
    padding:28px 60px;
    position:fixed;
    top:0;
    left:0;
    z-index:1000;
    backdrop-filter:blur(12px);
    background:var(--nav-bg);
    border-bottom:1px solid rgba(255,255,255,0.25);
    opacity:0;
    transform:translateY(-20px);
    transition:opacity 0.8s ease, transform 0.8s ease, background 0.3s ease;
}

nav.show{
    opacity:1;
    transform:translateY(0);
}

.logo-area{
    display:flex;
    align-items:center;
    gap:28px;
}

.logo{
    display:inline-flex;
    align-items:center;
    text-decoration:none;
    font-size:24px;
    letter-spacing:2px;
    color:var(--ink);
}

#clock{
    font-size:23px;
    letter-spacing:2px;
    color:var(--muted);
    font-weight:500;
    min-width:90px;
}

nav ul{
    display:flex;
    gap:35px;
    list-style:none;
}

nav ul li a{
    position:relative;
    text-decoration:none;
    color:var(--ink);
    font-size:18px;
    letter-spacing:1px;
    transition:0.3s ease;
}

nav ul li a::after{
    content:"";
    position:absolute;
    left:0;
    right:0;
    bottom:-8px;
    height:2px;
    background:var(--ink);
    transform:scaleX(0);
    transform-origin:center;
    transition:0.3s ease;
}

nav ul li a:hover,
nav ul li a.active{
    opacity:0.72;
}

nav ul li a.active::after{
    transform:scaleX(1);
}

.theme-toggle{
    width:42px;
    height:42px;
    border-radius:50%;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--surface);
    color:var(--ink);
    cursor:pointer;
    transition:0.3s ease;
    box-shadow:0 10px 30px rgba(0,0,0,0.05);
}

.theme-toggle:hover{
    transform:rotate(15deg);
}

/* HERO */

.hero{
    min-height:88vh;
    padding:160px 70px 60px;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
}

.home-hero{
    position:relative;
    min-height:100vh;
    padding-bottom:44px;
    overflow:hidden;
}

.home-orb{
    position:absolute;
    border-radius:50%;
    pointer-events:none;
    filter:blur(0px);
}

.home-orb-one{
    /* Large warm forest ambient left */
    width:700px;
    height:700px;
    left:-260px;
    top:60px;
    background:radial-gradient(circle, rgba(51,77,66,0.10) 0%, rgba(96,116,102,0.06) 42%, transparent 72%);
    filter:blur(2px);
}

.home-orb-two{
    /* Cool slate-blue ambient right */
    width:580px;
    height:580px;
    right:-200px;
    bottom:60px;
    background:radial-gradient(circle, rgba(62,111,142,0.09) 0%, rgba(96,130,155,0.05) 44%, transparent 72%);
    filter:blur(2px);
}

/* Home page — layered organic ambient background */
.home-hero{
    background:
        /* Fine scattered dust: tiny radials not in a grid pattern */
        radial-gradient(ellipse 380px 240px at 8% 30%, rgba(51,77,66,0.055) 0%, transparent 100%),
        radial-gradient(ellipse 520px 380px at 92% 14%, rgba(62,111,142,0.052) 0%, transparent 100%),
        radial-gradient(ellipse 300px 500px at 72% 88%, rgba(138,111,77,0.042) 0%, transparent 100%),
        radial-gradient(ellipse 440px 280px at 22% 80%, rgba(96,116,102,0.038) 0%, transparent 100%),
        radial-gradient(ellipse 200px 200px at 55% 48%, rgba(31,45,37,0.028) 0%, transparent 100%),
        /* Barely-visible topographic contour arcs */
        radial-gradient(ellipse 900px 700px at 18% 22%, rgba(31,45,37,0.022) 0%, transparent 55%),
        radial-gradient(ellipse 800px 600px at 82% 78%, rgba(62,111,142,0.018) 0%, transparent 55%),
        var(--bg);
}

.hero-container{
    width:100%;
    max-width:1450px;
    margin:auto;
    display:grid;
    grid-template-columns:1.1fr 0.9fr;
    align-items:center;
    gap:80px;
}

.home-hero-container{
    position:relative;
    z-index:1;
}

.hero-left{
    display:flex;
    flex-direction:column;
    align-items:flex-start;
}

.hero-tag{
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    margin-bottom:28px;
    color:#707070;
}

.hero-left h1{
    font-size:clamp(78px,10vw,150px);
    line-height:0.88;
    letter-spacing:-7px;
    color:var(--ink);
    margin-bottom:35px;
    font-weight:700;
}

.hero-statement{
    max-width:760px;
    font-size:clamp(34px,4.6vw,72px);
    line-height:1.04;
    letter-spacing:-3px;
    color:var(--ink);
    margin-bottom:28px;
}

.hero-description{
    max-width:560px;
    font-size:22px;
    line-height:1.85;
    font-weight:300;
    color:var(--soft);
    margin-bottom:34px;
}

.hero-actions{
    display:flex;
    flex-wrap:wrap;
    gap:16px;
    margin-bottom:34px;
}

.primary-btn,
.ghost-btn{
    min-height:52px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    padding:0 24px;
    border-radius:100px;
    text-decoration:none;
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    transition:0.35s ease;
}

.primary-btn{
    background:var(--ink);
    color:#F5F1EA;
}

.ghost-btn{
    background:var(--surface);
    color:var(--ink);
    border:1px solid rgba(31,45,37,0.1);
}

.primary-btn:hover,
.ghost-btn:hover{
    transform:translateY(-5px);
}

.ghost-btn:hover{
    background:var(--ink);
    color:#F5F1EA;
}

.hero-links{
    display:flex;
    gap:35px;
    margin-bottom:45px;
}

.hero-links a{
    text-decoration:none;
    color:var(--ink);
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:14px;
    position:relative;
}

.hero-links a::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-8px;
    width:100%;
    height:1px;
    background:var(--ink);
}

.hero-links a:hover{
    opacity:0.6;
}

.hero-right{
    display:flex;
    justify-content:flex-end;
    padding-right:40px;
}

.portrait-system{
    --portrait-x:50%;
    --portrait-y:50%;
    position:relative;
    width:min(100%,560px);
    min-height:720px;
    display:flex;
    align-items:center;
    justify-content:center;
    transform-style:preserve-3d;
}

.portrait-system::before{
    content:"";
    position:absolute;
    inset:36px 0 36px 70px;
    border:1px solid rgba(31,45,37,0.12);
    border-radius:28px;
    transform:rotate(4deg);
}

.portrait-system::after{
    content:"";
    position:absolute;
    width:310px;
    height:310px;
    border-radius:50%;
    background:radial-gradient(circle, rgba(31,45,37,0.14), transparent 70%);
    left:var(--portrait-x);
    top:var(--portrait-y);
    transform:translate(-50%,-50%);
    pointer-events:none;
}

.portrait-frame{
    position:relative;
    width:100%;
    max-width:500px;
    height:720px;
    border-radius:24px;
    overflow:hidden;
    box-shadow:0 30px 90px rgba(31,45,37,0.18);
}

.portrait-frame img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:0.7s ease;
    filter:grayscale(8%);
}

.portrait-frame:hover img{
    transform:scale(1.04);
    filter:grayscale(0%);
}

.portrait-chip,
.signal-card{
    position:absolute;
    z-index:2;
    background:rgba(255,253,248,0.78);
    border:1px solid rgba(31,45,37,0.1);
    backdrop-filter:blur(14px);
    color:var(--ink);
    box-shadow:0 18px 50px rgba(31,45,37,0.12);
}

.portrait-chip{
    padding:12px 18px;
    border-radius:100px;
    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;
}

.chip-one{
    top:96px;
    left:4px;
}

.chip-two{
    right:-4px;
    top:260px;
}

.chip-three{
    left:40px;
    bottom:135px;
}

.signal-card{
    right:-12px;
    bottom:76px;
    width:230px;
    padding:20px;
    border-radius:14px;
}

.signal-card p{
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:10px;
}

.signal-card strong{
    font-size:18px;
    line-height:1.35;
}

.social-icons,
.footer-icons{
    display:flex;
    gap:18px;
}

.social-icons a,
.footer-icons a{
    width:48px;
    height:48px;
    border-radius:50%;
    display:flex;
    justify-content:center;
    align-items:center;
    text-decoration:none;
    background:var(--surface);
    color:var(--ink);
    transition:0.3s ease;
}

.social-icons a:hover,
.footer-icons a:hover{
    transform:translateY(-4px);
    opacity:0.75;
}

.hero-strip{
    width:100%;
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:20px;
    padding-top:30px;
    margin-top:40px;
    border-top:1px solid var(--line);
}

.hero-strip span{
    font-size:13px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:#666;
}

.home-marquee{
    position:relative;
    z-index:1;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    overflow:hidden;
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    padding:22px 0;
    margin-top:42px;
}

.marquee-track{
    display:flex;
    width:max-content;
    gap:34px;
    animation:marqueeMove 28s linear infinite;
}

.marquee-track span{
    color:#666;
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    white-space:nowrap;
}

@keyframes marqueeMove{
    to{
        transform:translateX(-50%);
    }
}

.home-signal-section,
.gateway-section{
    max-width:1400px;
    margin:0 auto;
    padding:0 80px 120px;
}

.signal-panel{
    display:grid;
    grid-template-columns:0.9fr 1.1fr;
    gap:60px;
    align-items:center;
    padding:54px;
    border-radius:18px;
    background:rgba(255,253,248,0.72);
    border:1px solid rgba(31,45,37,0.08);
    box-shadow:var(--shadow);
}

.section-label{
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:18px;
}

.signal-panel h2{
    font-size:clamp(34px,4vw,58px);
    line-height:1.08;
    letter-spacing:-2px;
    color:var(--ink);
}

.signal-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:14px;
}

.signal-grid span{
    min-height:92px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:20px;
    border-radius:12px;
    background:var(--bg);
    color:var(--ink);
    font-size:18px;
    transition:0.35s ease;
}

.signal-grid span:hover{
    transform:translateY(-6px);
    background:var(--ink);
    color:#F5F1EA;
}

.gateway-section{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:22px;
}

.gateway-card{
    position:relative;
    min-height:270px;
    padding:30px;
    border-radius:14px;
    background:var(--surface);
    border:1px solid rgba(31,45,37,0.08);
    color:var(--ink);
    text-decoration:none;
    overflow:hidden;
    transition:0.4s ease;
}

.gateway-card::before{
    content:"";
    position:absolute;
    inset:auto 0 0 0;
    height:0;
    background:var(--ink);
    transition:0.4s ease;
}

.gateway-card span,
.gateway-card h3,
.gateway-card p,
.gateway-card i{
    position:relative;
    z-index:1;
}

.gateway-card span{
    display:block;
    font-size:13px;
    letter-spacing:4px;
    color:var(--muted);
    margin-bottom:54px;
}

.gateway-card h3{
    font-size:34px;
    letter-spacing:-1px;
    margin-bottom:16px;
}

.gateway-card p{
    font-size:17px;
    line-height:1.75;
    color:#555;
    max-width:300px;
}

.gateway-card i{
    position:absolute;
    right:28px;
    bottom:28px;
    transition:0.4s ease;
}

.gateway-card:hover{
    transform:translateY(-10px);
}

.gateway-card:hover::before{
    height:100%;
}

.gateway-card:hover span,
.gateway-card:hover h3,
.gateway-card:hover p,
.gateway-card:hover i{
    color:#F5F1EA;
}

.gateway-card:hover i{
    transform:translateX(6px);
}

/* ABOUT PAGE */

.about-page{
    position:relative;
    min-height:100vh;
    padding:0 0 120px;
    overflow:hidden;
    background:
        /* Organic scattered radial lights — no grid, no blocks */
        radial-gradient(ellipse 600px 400px at 5% 12%, rgba(96,116,102,0.07) 0%, transparent 100%),
        radial-gradient(ellipse 400px 600px at 96% 38%, rgba(138,111,77,0.055) 0%, transparent 100%),
        radial-gradient(ellipse 700px 300px at 50% 72%, rgba(62,111,142,0.038) 0%, transparent 100%),
        radial-gradient(ellipse 300px 400px at 18% 88%, rgba(51,77,66,0.042) 0%, transparent 100%),
        radial-gradient(ellipse 500px 350px at 78% 92%, rgba(96,116,102,0.032) 0%, transparent 100%),
        /* Diagonal gossamer sweep — like light through venetian blinds, barely visible */
        repeating-linear-gradient(
            -52deg,
            transparent 0px,
            transparent 88px,
            rgba(31,45,37,0.012) 89px,
            rgba(31,45,37,0.012) 90px,
            transparent 91px,
            transparent 178px
        ),
        /* Base */
        var(--bg);
    background-size:auto, auto, auto, auto, auto, auto, auto;
}

.about-page::before{
    content:"OBSERVER";
    position:absolute;
    top:240px;
    right:-70px;
    z-index:0;
    font-size:clamp(90px,14vw,260px);
    line-height:1;
    letter-spacing:-10px;
    font-weight:700;
    color:rgba(31,45,37,0.055);
    pointer-events:none;
}

.about-page::after{
    content:"SYSTEMS / MATERIALS / LIGHT / DETAILS";
    position:absolute;
    left:80px;
    bottom:120px;
    z-index:0;
    max-width:500px;
    font-size:13px;
    letter-spacing:5px;
    line-height:2.2;
    color:rgba(31,45,37,0.22);
    pointer-events:none;
    writing-mode:vertical-rl;
}

.about-hero,
.about-page-content{
    position:relative;
    z-index:1;
}

.about-hero{
    max-width:1400px;
    margin:auto;
    padding:190px 80px 110px;
}

.about-mini-title{
    font-size:clamp(15px,1.7vw,27px);
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:30px;
}

.about-hero h1{
    font-size:clamp(58px,8.6vw,130px);
    line-height:1.05;
    letter-spacing:-6px;
    color:var(--ink);
    max-width:1120px;
}

.about-page-content{
    width:100%;
    max-width:1400px;
    margin:auto;
    display:grid;
    grid-template-columns:minmax(240px,0.7fr) minmax(0,1.3fr);
    gap:clamp(60px,8vw,120px);
    align-items:start;
    padding:0 80px;
}

.about-sticky{
    position:sticky;
    top:140px;
}

.about-sticky h2{
    font-size:clamp(48px,5vw,70px);
    margin-bottom:20px;
    color:var(--ink);
    letter-spacing:-2px;
}

.about-sticky p{
    font-size:clamp(15px,1.35vw,22px);
    letter-spacing:2px;
    text-transform:uppercase;
    color:var(--muted);
    line-height:2;
}

.about-content-area{
    width:100%;
    min-width:0;
}

.about-text{
    width:100%;
}

.about-text p{
    font-size:clamp(20px,2.25vw,34px);
    line-height:1.85;
    font-weight:300;
    color:#3D3D3D;
    margin-bottom:52px;
    max-width:900px;
}

.about-text strong{
    color:var(--ink);
    font-weight:600;
}

/* VISUAL JOURNAL */

.visual-journal{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:25px;
    margin:120px 0;
}

.journal-card{
    position:relative;
    overflow:hidden;
    border-radius:var(--radius);
    height:320px;
    background:#ded8ce;
    box-shadow:var(--shadow);
}

.journal-card.large{
    grid-column:span 2;
    height:500px;
}

.journal-card img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:0.7s ease;
}

.journal-card::after{
    content:"";
    position:absolute;
    inset:auto 18px 18px 18px;
    min-height:44px;
    display:flex;
    align-items:center;
    padding:0 18px;
    border-radius:100px;
    background:rgba(245,241,234,0.82);
    color:var(--ink);
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    opacity:0;
    transform:translateY(14px);
    transition:0.4s ease;
    backdrop-filter:blur(10px);
}

.journal-card.large::after{
    content:"Visual Journal";
}

.journal-card:nth-child(2)::after{
    content:"Where I Notice Details";
}

.journal-card:nth-child(3)::after{
    content:"Moments, Materials, Systems";
}

.journal-card:hover img{
    transform:scale(1.06);
}

.journal-card:hover::after{
    opacity:1;
    transform:translateY(0);
}

/* INTERESTS */

.interests-section{
    margin:160px 0;
}

.interests-section h3,
.currently-section h3{
    font-size:30px;
    letter-spacing:4px;
    text-transform:uppercase;
    margin-bottom:40px;
    color:var(--muted);
}

.interests-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}

.interest-card{
    position:relative;
    min-height:165px;
    padding:34px;
    border:0;
    border-radius:var(--radius-small);
    background:var(--surface);
    color:var(--ink);
    font:inherit;
    font-size:27px;
    font-weight:500;
    text-align:left;
    cursor:pointer;
    appearance:none;
    overflow:hidden;
    transition:0.4s ease;
    box-shadow:0 18px 50px rgba(31,45,37,0.06);
}

.interest-card:focus-visible{
    outline:2px solid var(--ink);
    outline-offset:4px;
}

.interest-card::after{
    position:absolute;
    left:34px;
    right:34px;
    bottom:28px;
    font-size:13px;
    line-height:1.7;
    font-weight:400;
    color:rgba(245,245,245,0.82);
    opacity:0;
    transform:translateY(12px);
    transition:0.4s ease;
}

.interest-card:hover{
    background:var(--ink);
    color:#F5F1EA;
    transform:translateY(-8px);
}

.interest-card:hover::after{
    opacity:1;
    transform:translateY(0);
    color:rgba(245,241,234,0.9);
}

/* CURRENTLY */

.currently-section{
    margin:160px 0;
}

.currently-list{
    display:flex;
    flex-wrap:wrap;
    gap:18px;
}

.currently-list span{
    position:relative;
    padding:16px 26px;
    border-radius:100px;
    background:var(--surface);
    color:var(--ink);
    font-size:20px;
    overflow:hidden;
    transition:0.35s ease;
}

.currently-list span:hover{
    transform:translateY(-5px);
    background:var(--ink);
    color:#F5F1EA;
}

/* PHILOSOPHY */

.philosophy-section{
    margin-top:180px;
}

.philosophy-section h2{
    font-size:clamp(42px,5.2vw,72px);
    line-height:1.18;
    letter-spacing:-3px;
    color:var(--ink);
    max-width:1000px;
}

/* EXPERIENCE PAGE */

.experience-page{
    min-height:100vh;
    padding:180px 80px 120px;
}

.experience-container{
    width:100%;
    max-width:1400px;
    margin:auto;
}

.experience-heading{
    margin-bottom:120px;
}

.experience-heading p{
    font-size:23px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:20px;
}

.experience-heading h1{
    font-size:clamp(58px,7.4vw,110px);
    line-height:0.9;
    letter-spacing:-5px;
    color:var(--ink);
}

.experience-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
}

.experience-item{
    position:relative;
    padding:50px;
    border-radius:var(--radius);
    background:rgba(255,255,255,0.35);
    backdrop-filter:blur(10px);
    border:1px solid rgba(0,0,0,0.05);
    overflow:hidden;
    transition:0.5s ease;
}

.experience-item:hover{
    transform:translateY(-12px);
    background:var(--ink);
}

.experience-item::before{
    content:"";
    position:absolute;
    width:300px;
    height:300px;
    background:rgba(255,255,255,0.08);
    border-radius:50%;
    top:-120px;
    right:-120px;
    transition:0.5s ease;
}

.experience-item:hover::before{
    transform:scale(1.2);
}

.experience-content{
    position:relative;
    z-index:1;
}

.experience-content h2{
    font-size:52px;
    line-height:1;
    letter-spacing:-2px;
    margin-bottom:20px;
    color:var(--ink);
    transition:0.4s ease;
}

.experience-content h3{
    font-size:24px;
    letter-spacing:3px;
    text-transform:uppercase;
    margin-bottom:35px;
    color:#666;
    transition:0.4s ease;
}

.experience-content p{
    font-size:25px;
    line-height:1.9;
    font-weight:300;
    color:#3D3D3D;
    margin-bottom:25px;
    transition:0.4s ease;
}

.experience-item:hover h2,
.experience-item:hover h3,
.experience-item:hover p{
    color:#F5F5F5;
}

.resume-section{
    margin-top:80px;
    display:flex;
    justify-content:center;
}

.resume-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:20px 42px;
    border-radius:100px;
    background:var(--ink);
    color:#F5F1EA;
    text-decoration:none;
    font-size:14px;
    letter-spacing:3px;
    text-transform:uppercase;
    transition:0.4s ease;
}

.resume-btn:hover{
    transform:translateY(-6px);
    opacity:0.9;
}

/* FOOTER */

footer{
    width:100%;
    padding:25px 70px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    border-top:1px solid var(--line);
    background:var(--bg);
}

footer p{
    color:var(--soft);
}

/* STAGED REVEALS */

.reveal-name,
.reveal-content{
    opacity:0;
    transform:translateY(70px);
    transition:1.2s ease;
}

.reveal-image{
    opacity:0;
    transform:translateY(100px);
    filter:blur(10px);
    transition:1.4s ease;
}

.reveal-name.show,
.reveal-content.show{
    opacity:1;
    transform:translateY(0);
}

.reveal-image.show{
    opacity:1;
    transform:translateY(0);
    filter:blur(0);
}

/* DARK MODE */

.dark-mode{
    background:#121212;
    color:#FFFFFF;
}

.dark-mode .intro-screen{
    background:
        radial-gradient(circle at 50% 42%, rgba(245,245,245,0.08), transparent 32%),
        #121212;
}

.dark-mode #intro-clock,
.dark-mode .logo,
.dark-mode nav ul li a,
.dark-mode .hero-left h1,
.dark-mode .hero-statement,
.dark-mode .about-hero h1,
.dark-mode .about-sticky h2,
.dark-mode .philosophy-section h2,
.dark-mode .experience-heading h1,
.dark-mode .experience-content h2,
.dark-mode .signal-panel h2{
    color:#F5F5F5;
}

.dark-mode .intro-content p,
.dark-mode #clock,
.dark-mode .hero-description,
.dark-mode .hero-tag,
.dark-mode .hero-strip span,
.dark-mode footer p,
.dark-mode .about-mini-title,
.dark-mode .about-sticky p,
.dark-mode .interests-section h3,
.dark-mode .currently-section h3,
.dark-mode .experience-heading p,
.dark-mode .experience-content h3,
.dark-mode .section-label{
    color:#C9C9C9;
}

.dark-mode nav{
    background:rgba(18,18,18,0.65);
    border-bottom-color:rgba(255,255,255,0.08);
}

.dark-mode nav ul li a::after,
.dark-mode .hero-links a::after{
    background:#F5F5F5;
}

.dark-mode .hero-links a{
    color:#F5F5F5;
}

.dark-mode .about-text p,
.dark-mode .experience-content p{
    color:#D6D6D6;
}

.dark-mode .about-text strong{
    color:#FFFFFF;
}

.dark-mode .social-icons a,
.dark-mode .footer-icons a,
.dark-mode .theme-toggle,
.dark-mode .interest-card,
.dark-mode .currently-list span,
.dark-mode .ghost-btn,
.dark-mode .portrait-chip,
.dark-mode .signal-card,
.dark-mode .signal-panel,
.dark-mode .gateway-card{
    background:#1E1E1E;
    color:#F5F5F5;
}

.dark-mode .signal-grid span{
    background:#121212;
    color:#F5F5F5;
}

.dark-mode .signal-grid span:hover,
.dark-mode .gateway-card::before,
.dark-mode .ghost-btn:hover,
.dark-mode .interest-card:hover,
.dark-mode .currently-list span:hover{
    background:#F5F5F5;
    color:#121212;
}

.dark-mode .gateway-card p,
.dark-mode .signal-card p{
    color:#C9C9C9;
}

.dark-mode .gateway-card:hover p,
.dark-mode .gateway-card:hover h3,
.dark-mode .gateway-card:hover span,
.dark-mode .gateway-card:hover i{
    color:#121212;
}

.dark-mode .interest-card:hover::after{
    color:rgba(18,18,18,0.72);
}

.dark-mode .journal-card::after{
    background:rgba(18,18,18,0.78);
    color:#F5F5F5;
}

.dark-mode .experience-item{
    background:rgba(255,255,255,0.03);
    border-color:rgba(255,255,255,0.08);
}

.dark-mode .hero-strip,
.dark-mode .home-marquee,
.dark-mode footer{
    border-color:rgba(255,255,255,0.08);
}

.dark-mode,
.dark-mode .hero,
.dark-mode .about-page,
.dark-mode .experience-page,
.dark-mode footer{
    background:#121212;
}

/* Dark home hero keeps its own organic layers */
.dark-mode .home-hero{
    background:
        radial-gradient(ellipse 380px 240px at 8% 30%, rgba(96,116,102,0.10) 0%, transparent 100%),
        radial-gradient(ellipse 520px 380px at 92% 14%, rgba(62,111,142,0.09) 0%, transparent 100%),
        radial-gradient(ellipse 300px 500px at 72% 88%, rgba(138,111,77,0.07) 0%, transparent 100%),
        radial-gradient(ellipse 440px 280px at 22% 80%, rgba(96,116,102,0.065) 0%, transparent 100%),
        radial-gradient(ellipse 200px 200px at 55% 48%, rgba(245,245,245,0.022) 0%, transparent 100%),
        radial-gradient(ellipse 900px 700px at 18% 22%, rgba(51,77,66,0.052) 0%, transparent 55%),
        radial-gradient(ellipse 800px 600px at 82% 78%, rgba(62,111,142,0.038) 0%, transparent 55%),
        #121212;
}

/* INTEREST POPUP - ENHANCED */

.interest-modal{
    --interest-accent:#607466;
    position:fixed;
    inset:0;
    z-index:5000;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    opacity:0;
    pointer-events:none;
    transition:0.35s ease;
}

.interest-modal.show{
    opacity:1;
    pointer-events:auto;
}

.interest-modal-backdrop{
    position:absolute;
    inset:0;
    background:
        radial-gradient(circle at 25% 20%, color-mix(in srgb, var(--interest-accent) 38%, transparent), transparent 32%),
        rgba(18,18,18,0.55);
    backdrop-filter:blur(16px);
}

.interest-window{
    --mouse-x:50%;
    --mouse-y:50%;
    --tilt-x:0deg;
    --tilt-y:0deg;
    position:relative;
    width:min(820px,100%);
    padding:48px;
    border-radius:22px;
    background:
        radial-gradient(circle at var(--mouse-x) var(--mouse-y), color-mix(in srgb, var(--interest-accent) 20%, transparent), transparent 32%),
        linear-gradient(135deg, rgba(255,255,255,0.92), rgba(245,241,234,0.86));
    color:#1F2D25;
    box-shadow:0 40px 140px rgba(0,0,0,0.32);
    overflow:hidden;
    transform:translateY(28px) scale(0.96) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
    transition:0.35s ease;
    transform-style:preserve-3d;
}

.interest-modal.show .interest-window{
    transform:translateY(0) scale(1) rotateX(var(--tilt-x)) rotateY(var(--tilt-y));
}

.interest-window::before{
    content:"";
    position:absolute;
    inset:0;
    border:1px solid rgba(31,45,37,0.12);
    border-radius:22px;
    pointer-events:none;
}

.interest-window::after{
    content:"";
    position:absolute;
    inset:0;
    background-image:
        linear-gradient(rgba(31,45,37,0.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(31,45,37,0.045) 1px, transparent 1px);
    background-size:34px 34px;
    opacity:0.45;
    pointer-events:none;
}

.interest-orbit{
    position:absolute;
    right:-90px;
    top:-90px;
    width:310px;
    height:310px;
    border-radius:50%;
    border:1px solid color-mix(in srgb, var(--interest-accent) 50%, transparent);
    opacity:0.55;
    animation:interestSpin 18s linear infinite;
}

.interest-orbit span{
    position:absolute;
    border-radius:50%;
    border:1px solid color-mix(in srgb, var(--interest-accent) 55%, transparent);
}

.interest-orbit span:nth-child(1){
    inset:38px;
}

.interest-orbit span:nth-child(2){
    inset:78px;
}

.interest-orbit span:nth-child(3){
    width:16px;
    height:16px;
    background:var(--interest-accent);
    top:28px;
    left:142px;
    border:0;
}

.interest-close{
    position:absolute;
    top:24px;
    right:24px;
    z-index:2;
    width:44px;
    height:44px;
    border:0;
    border-radius:50%;
    background:#FFFFFF;
    color:#1F2D25;
    cursor:pointer;
    font-size:18px;
    box-shadow:0 16px 40px rgba(0,0,0,0.12);
    transition:0.3s ease;
}

.interest-close:hover{
    transform:rotate(90deg) scale(1.05);
    background:var(--interest-accent);
    color:#FFFFFF;
}

.interest-window-top,
.interest-window-main,
.interest-detail-grid,
.interest-signal,
.interest-window-actions{
    position:relative;
    z-index:1;
}

.interest-window-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    margin-bottom:34px;
    padding-right:60px;
}

.interest-window-label,
.interest-window-top span{
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:#777;
}

.interest-window-main{
    display:grid;
    grid-template-columns:auto 1fr;
    gap:34px;
    align-items:start;
    margin-bottom:34px;
}

.interest-window-number{
    font-size:96px;
    line-height:0.85;
    font-weight:700;
    letter-spacing:-6px;
    color:var(--interest-accent);
}

.interest-window h2{
    font-size:64px;
    line-height:0.95;
    letter-spacing:-3px;
    margin-bottom:20px;
}

.interest-window p{
    font-size:20px;
    line-height:1.85;
    color:#3D3D3D;
}

.interest-detail-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
    margin:34px 0;
}

.interest-detail-card{
    min-height:138px;
    padding:20px;
    border-radius:14px;
    background:rgba(255,255,255,0.62);
    border:1px solid rgba(31,45,37,0.08);
    transition:0.3s ease;
}

.interest-detail-card:hover{
    transform:translateY(-6px);
    background:var(--interest-accent);
}

.interest-detail-card span{
    display:block;
    font-size:12px;
    letter-spacing:3px;
    color:var(--interest-accent);
    margin-bottom:18px;
}

.interest-detail-card p{
    font-size:15px;
    line-height:1.7;
    color:#1F2D25;
}

.interest-detail-card:hover span,
.interest-detail-card:hover p{
    color:#FFFFFF;
}

.interest-signal{
    display:flex;
    justify-content:space-between;
    gap:18px;
    align-items:center;
    padding:18px 22px;
    border-radius:100px;
    background:rgba(31,45,37,0.08);
    margin-bottom:30px;
}

.interest-signal span{
    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:#777;
}

.interest-signal strong{
    font-size:16px;
    color:#1F2D25;
}

.interest-window-actions{
    display:grid;
    grid-template-columns:auto 1fr auto;
    align-items:center;
    gap:18px;
}

.interest-nav-btn{
    border:0;
    border-radius:100px;
    padding:14px 18px;
    background:#FFFFFF;
    color:#1F2D25;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    transition:0.3s ease;
}

.interest-nav-btn:hover{
    background:var(--interest-accent);
    color:#FFFFFF;
    transform:translateY(-3px);
}

.interest-progress{
    height:2px;
    background:rgba(31,45,37,0.12);
    overflow:hidden;
}

.interest-progress span{
    display:block;
    width:0;
    height:100%;
    background:var(--interest-accent);
    transition:0.4s ease;
}

.interest-modal-open{
    overflow:hidden;
}

@keyframes interestSpin{
    to{
        transform:rotate(360deg);
    }
}

.dark-mode .interest-window{
    background:
        radial-gradient(circle at var(--mouse-x) var(--mouse-y), color-mix(in srgb, var(--interest-accent) 24%, transparent), transparent 32%),
        linear-gradient(135deg, rgba(30,30,30,0.96), rgba(18,18,18,0.92));
    color:#F5F5F5;
}

.dark-mode .interest-window p,
.dark-mode .interest-detail-card p,
.dark-mode .interest-signal strong{
    color:#D6D6D6;
}

.dark-mode .interest-close,
.dark-mode .interest-nav-btn,
.dark-mode .interest-detail-card{
    background:#1E1E1E;
    color:#F5F5F5;
}

.dark-mode .interest-detail-card{
    border-color:rgba(255,255,255,0.08);
}

.dark-mode .interest-signal{
    background:rgba(255,255,255,0.06);
}

/* TABLET */

@media(max-width:1100px){
    nav{
        padding:25px;
        flex-direction:column;
        gap:20px;
    }

    nav ul{
        gap:22px;
        flex-wrap:wrap;
        justify-content:center;
    }

    .hero{
        padding:190px 25px 60px;
    }

    .hero-container{
        grid-template-columns:1fr;
        gap:60px;
    }

    .hero-left{
        align-items:center;
        text-align:center;
    }

    .hero-left h1{
        letter-spacing:-4px;
    }

    .hero-description{
        font-size:18px;
    }

    .hero-actions{
        justify-content:center;
    }

    .hero-right{
        justify-content:center;
        padding-right:0;
    }

    .portrait-system{
        min-height:520px;
        max-width:430px;
    }

    .portrait-frame{
        max-width:360px;
        height:500px;
    }

    .signal-card{
        right:0;
        bottom:24px;
    }

    .home-signal-section,
    .gateway-section{
        padding:0 25px 80px;
    }

    .signal-panel{
        grid-template-columns:1fr;
        padding:34px;
    }

    .gateway-section{
        grid-template-columns:1fr;
    }

    .hero-strip{
        justify-content:center;
    }

    .about-hero{
        padding:210px 25px 80px;
    }

    .about-hero h1{
        letter-spacing:-3px;
    }

    .about-page-content{
        grid-template-columns:1fr;
        gap:60px;
        padding:0 25px;
    }

    .about-sticky{
        position:relative;
        top:auto;
    }

    .visual-journal{
        grid-template-columns:1fr;
        margin:80px 0;
    }

    .journal-card,
    .journal-card.large{
        grid-column:span 1;
        height:420px;
    }

    .interests-grid{
        grid-template-columns:1fr 1fr;
    }

    .experience-page{
        padding:170px 25px 80px;
    }

    .experience-heading{
        margin-bottom:70px;
    }

    .experience-grid{
        grid-template-columns:1fr;
    }

    .experience-content h2{
        font-size:38px;
    }

    .experience-content p{
        font-size:18px;
    }

    footer{
        padding:25px;
        flex-direction:column;
        gap:25px;
        text-align:center;
    }
}

@media(max-width:760px){
    .interest-window{
        padding:34px 24px;
    }

    .interest-window-main{
        grid-template-columns:1fr;
        gap:16px;
    }

    .interest-window-number{
        font-size:68px;
    }

    .interest-window h2{
        font-size:42px;
    }

    .interest-window p{
        font-size:17px;
    }

    .interest-detail-grid{
        grid-template-columns:1fr;
    }

    .interest-window-actions{
        grid-template-columns:1fr;
    }

    .interest-signal{
        align-items:flex-start;
        border-radius:18px;
        flex-direction:column;
    }
}

/* MOBILE */

@media(max-width:600px){
    #clock{
        font-size:16px;
        min-width:auto;
    }

    .logo-area{
        gap:16px;
    }

    nav ul{
        gap:16px;
    }

    nav ul li a{
        font-size:14px;
    }

    .hero-left h1{
        font-size:58px;
        line-height:0.95;
        letter-spacing:-3px;
    }

    .hero-statement{
        font-size:34px;
        letter-spacing:-1px;
    }

    .hero-description{
        font-size:16px;
    }

    .hero-actions{
        width:100%;
        flex-direction:column;
    }

    .primary-btn,
    .ghost-btn{
        width:100%;
    }

    .portrait-system{
        min-height:390px;
    }

    .portrait-frame{
        max-width:250px;
        height:340px;
        border-radius:18px;
    }

    .portrait-system::before,
    .portrait-system::after{
        display:none;
    }

    .portrait-chip{
        font-size:10px;
        padding:10px 12px;
    }

    .chip-one{
        top:25px;
        left:10px;
    }

    .chip-two{
        top:132px;
        right:4px;
    }

    .chip-three{
        bottom:42px;
        left:18px;
    }

    .signal-card{
        width:190px;
        right:8px;
        bottom:0;
        padding:15px;
    }

    .signal-grid{
        grid-template-columns:1fr;
    }

    .gateway-card{
        min-height:235px;
    }

    .about-hero{
        padding-top:210px;
    }

    .about-mini-title{
        letter-spacing:2px;
    }

    .about-hero h1{
        font-size:48px;
        line-height:1.08;
    }

    .about-sticky h2{
        font-size:46px;
    }

    .about-sticky p{
        font-size:14px;
    }

    .about-text p{
        font-size:18px;
        line-height:1.9;
        margin-bottom:38px;
    }

    .journal-card,
    .journal-card.large{
        height:300px;
    }

    .interests-grid{
        grid-template-columns:1fr;
    }

    .interest-card{
        min-height:150px;
        padding:28px;
        font-size:21px;
    }

    .interest-card::after{
        left:28px;
        right:28px;
        bottom:24px;
    }

    .currently-list span{
        font-size:15px;
        padding:13px 20px;
    }

    .philosophy-section{
        margin-top:110px;
    }

    .philosophy-section h2{
        font-size:36px;
        letter-spacing:-2px;
    }

    .experience-heading h1{
        font-size:48px;
    }

    .experience-item{
        padding:35px;
    }

    .experience-content h2{
        font-size:30px;
    }

    .experience-content p{
        font-size:16px;
        line-height:1.8;
    }
}

/* ACCESSIBILITY */

@media(prefers-reduced-motion:reduce){
    html{
        scroll-behavior:auto;
    }

    *,
    *::before,
    *::after{
        transition:none !important;
        animation:none !important;
    }
}

/* SHARED INNER PAGES */

.system-page{
    position:relative;
    min-height:100vh;
    padding:180px 80px 120px;
    overflow:hidden;
    /* Base: transparent — each child page (experience-page, projects-page) sets its own bg */
    background:var(--bg);
}

.system-page::before{
    content:"";
    position:absolute;
    width:480px;
    height:480px;
    border-radius:50%;
    right:-190px;
    top:140px;
    background:radial-gradient(circle, rgba(31,45,37,0.042) 0%, transparent 68%);
    filter:blur(0px);
    pointer-events:none;
}

.experience-page{
    background:
        /* Warm corner blooms — like daylight pooling on a blueprint */
        radial-gradient(ellipse 560px 420px at 6% 18%, rgba(96,116,102,0.065) 0%, transparent 100%),
        radial-gradient(ellipse 460px 560px at 94% 72%, rgba(51,77,66,0.048) 0%, transparent 100%),
        radial-gradient(ellipse 340px 340px at 50% 5%, rgba(62,111,142,0.038) 0%, transparent 100%),
        radial-gradient(ellipse 280px 480px at 82% 22%, rgba(138,111,77,0.03) 0%, transparent 100%),
        /* Ultra-fine horizontal whisper lines — blueprint memory, not a grid */
        repeating-linear-gradient(
            0deg,
            transparent 0px,
            transparent 62px,
            rgba(31,45,37,0.016) 63px,
            rgba(31,45,37,0.016) 64px,
            transparent 65px
        ),
        /* Vertical accent lines spaced wide — like column marks */
        repeating-linear-gradient(
            90deg,
            transparent 0px,
            transparent 194px,
            rgba(31,45,37,0.01) 195px,
            rgba(31,45,37,0.01) 196px,
            transparent 197px
        ),
        var(--bg);
    background-size:auto, auto, auto, auto, auto, auto, auto;
}

.projects-page{
    background:
        /* Corner radial burns — like studio lights or vignette */
        radial-gradient(ellipse 500px 500px at 95% 5%, rgba(62,111,142,0.07) 0%, transparent 100%),
        radial-gradient(ellipse 420px 600px at 3% 95%, rgba(96,116,102,0.06) 0%, transparent 100%),
        radial-gradient(ellipse 600px 400px at 50% 50%, rgba(31,45,37,0.025) 0%, transparent 100%),
        radial-gradient(ellipse 300px 300px at 88% 85%, rgba(138,111,77,0.038) 0%, transparent 100%),
        /* Very fine dot-field — organic scatter, not a grid block */
        radial-gradient(circle, rgba(31,45,37,0.065) 1px, transparent 1px),
        radial-gradient(circle, rgba(31,45,37,0.04) 1px, transparent 1px),
        var(--bg);
    background-size:
        auto, auto, auto, auto,
        38px 38px,
        19px 19px;
    background-position:
        0 0, 0 0, 0 0, 0 0,
        0 0,
        9.5px 9.5px;
}

.system-hero{
    position:relative;
    max-width:1400px;
    margin:0 auto 70px;
    z-index:1;
}

.system-label{
    font-size:15px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:26px;
}

.system-hero-grid{
    display:grid;
    grid-template-columns:0.95fr 1.05fr;
    gap:80px;
    align-items:end;
}

.system-hero h1{
    font-size:clamp(70px,9vw,132px);
    line-height:0.9;
    letter-spacing:-6px;
    color:var(--ink);
}

.system-hero p:not(.system-label){
    max-width:720px;
    font-size:24px;
    line-height:1.85;
    font-weight:300;
    color:#3D3D3D;
}

/* EXPERIENCE UPGRADE */

.experience-dashboard{
    position:relative;
    z-index:1;
    max-width:1400px;
    margin:0 auto 70px;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:18px;
}

.experience-stat{
    min-height:190px;
    padding:28px;
    border-radius:14px;
    background:var(--surface);
    border:1px solid rgba(31,45,37,0.08);
    box-shadow:var(--shadow);
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    transition:0.35s ease;
}

.experience-stat:hover{
    transform:translateY(-8px);
    background:var(--ink);
}

.experience-stat span{
    font-size:clamp(42px,5vw,72px);
    line-height:1;
    letter-spacing:-3px;
    font-weight:700;
    color:var(--ink);
    transition:0.35s ease;
}

.experience-stat p{
    font-size:15px;
    line-height:1.7;
    letter-spacing:2px;
    text-transform:uppercase;
    color:#666;
    transition:0.35s ease;
}

.experience-stat:hover span,
.experience-stat:hover p{
    color:#F5F1EA;
}

.experience-timeline{
    position:relative;
    z-index:1;
    max-width:1180px;
    margin:0 auto;
    display:grid;
    gap:28px;
}

.experience-timeline::before{
    content:"";
    position:absolute;
    top:20px;
    bottom:20px;
    left:34px;
    width:1px;
    background:rgba(31,45,37,0.14);
}

.experience-node{
    display:grid;
    grid-template-columns:70px 1fr;
    gap:30px;
    padding:0;
    border:0;
    background:transparent;
    backdrop-filter:none;
    overflow:visible;
}

.experience-node:hover{
    transform:none;
    background:transparent;
}

.experience-marker{
    position:relative;
    z-index:2;
    width:70px;
    height:70px;
    border-radius:50%;
    background:var(--surface);
    border:1px solid rgba(31,45,37,0.1);
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 18px 50px rgba(31,45,37,0.08);
}

.experience-marker span{
    font-size:13px;
    letter-spacing:3px;
    color:var(--ink);
}

.experience-node .experience-content{
    padding:38px;
    border-radius:18px;
    background:rgba(255,253,248,0.78);
    border:1px solid rgba(31,45,37,0.08);
    box-shadow:var(--shadow);
    transition:0.35s ease;
}

.experience-node:hover .experience-content{
    transform:translateY(-6px);
}

.experience-meta{
    display:flex;
    justify-content:space-between;
    gap:16px;
    flex-wrap:wrap;
    margin-bottom:24px;
}

.experience-meta span{
    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
}

.experience-node .experience-content h2{
    font-size:clamp(34px,4vw,58px);
    line-height:1;
    letter-spacing:-2px;
}

.experience-node .experience-content h3{
    font-size:18px;
    margin-bottom:24px;
}

.experience-node .experience-content p{
    max-width:860px;
    font-size:20px;
}

.experience-node:hover h2,
.experience-node:hover h3,
.experience-node:hover p{
    color:inherit;
}

.experience-more{
    max-height:0;
    overflow:hidden;
    opacity:0;
    transition:max-height 0.45s ease, opacity 0.35s ease;
}

.experience-node.is-open .experience-more{
    max-height:420px;
    opacity:1;
}

.experience-tags{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    margin:24px 0;
}

.experience-tags span{
    padding:11px 15px;
    border-radius:100px;
    background:var(--bg);
    color:var(--ink);
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
}

.experience-toggle{
    margin-top:18px;
    border:0;
    border-radius:100px;
    background:var(--ink);
    color:#F5F1EA;
    padding:14px 18px;
    display:inline-flex;
    align-items:center;
    gap:12px;
    cursor:pointer;
    font-size:12px;
    letter-spacing:2px;
    text-transform:uppercase;
    transition:0.3s ease;
}

.experience-toggle:hover{
    transform:translateY(-4px);
}

/* PROJECTS UPGRADE */

.project-controls{
    position:relative;
    z-index:1;
    max-width:1400px;
    margin:0 auto 32px;
    display:flex;
    flex-wrap:wrap;
    gap:12px;
}

.project-filter{
    border:0;
    border-radius:100px;
    padding:14px 20px;
    background:var(--surface);
    color:var(--ink);
    cursor:pointer;
    font-size:13px;
    letter-spacing:2px;
    text-transform:uppercase;
    transition:0.3s ease;
}

.project-filter:hover,
.project-filter.active{
    background:var(--ink);
    color:#F5F1EA;
    transform:translateY(-3px);
}

.projects-container.project-lab{
    position:relative;
    z-index:1;
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}

.project-card{
    display:flex;
    flex-direction:column;
    min-height:100%;
    border-radius:18px;
    overflow:hidden;
    background:var(--surface);
    border:1px solid rgba(31,45,37,0.08);
    box-shadow:var(--shadow);
    transition:0.4s ease;
}

.project-card.is-hidden{
    display:none;
}

.project-card:hover{
    transform:translateY(-10px);
}

.project-image{
    position:relative;
    height:260px;
    overflow:hidden;
    background:#ded8ce;
}

.project-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:0.6s ease;
}

.project-card:hover .project-image img{
    transform:scale(1.06);
}

.project-image-generated{
    background:
        radial-gradient(circle at 20% 20%, rgba(31,45,37,0.22), transparent 28%),
        linear-gradient(135deg, #F5F1EA, #C9D0C7);
}

.project-scan{
    position:absolute;
    inset:28px;
    display:grid;
    grid-template-columns:1.2fr 0.8fr;
    grid-template-rows:1fr 1fr;
    gap:14px;
}

.project-scan span{
    border-radius:10px;
    background:rgba(255,253,248,0.7);
    border:1px solid rgba(31,45,37,0.12);
}

.project-scan span:first-child{
    grid-row:span 2;
}

.project-content{
    flex:1;
    padding:28px;
    display:flex;
    flex-direction:column;
}

.project-meta{
    display:flex;
    justify-content:space-between;
    gap:12px;
    margin-bottom:26px;
}

.project-meta span{
    font-size:11px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
}

.project-content h2{
    font-size:32px;
    line-height:1.08;
    letter-spacing:-1px;
    color:var(--ink);
    margin-bottom:18px;
}

.project-content p{
    font-size:16px;
    line-height:1.75;
    color:#555;
    margin-bottom:28px;
}

.project-open{
    margin-top:auto;
    border:0;
    border-radius:100px;
    padding:14px 18px;
    background:var(--ink);
    color:#F5F1EA;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:12px;
    cursor:pointer;
    font-size:12px;
    letter-spacing:2px;
    text-transform:uppercase;
    transition:0.3s ease;
}

.project-open:hover{
    transform:translateY(-4px);
}

.project-modal{
    --project-accent:#607466;
    position:fixed;
    inset:0;
    z-index:5200;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    opacity:0;
    pointer-events:none;
    transition:0.35s ease;
}

.project-modal.show{
    opacity:1;
    pointer-events:auto;
}

.project-modal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(18,18,18,0.55);
    backdrop-filter:blur(14px);
}

.project-window{
    position:relative;
    width:min(780px,100%);
    padding:46px;
    border-radius:20px;
    background:
        radial-gradient(circle at 80% 10%, color-mix(in srgb, var(--project-accent) 22%, transparent), transparent 32%),
        rgba(245,241,234,0.94);
    color:var(--ink);
    box-shadow:0 40px 140px rgba(0,0,0,0.3);
    transform:translateY(24px) scale(0.96);
    transition:0.35s ease;
}

.project-modal.show .project-window{
    transform:translateY(0) scale(1);
}

.project-close{
    position:absolute;
    top:22px;
    right:22px;
    width:44px;
    height:44px;
    border:0;
    border-radius:50%;
    background:#FFFFFF;
    color:var(--ink);
    cursor:pointer;
    transition:0.3s ease;
}

.project-close:hover{
    transform:rotate(90deg);
    background:var(--ink);
    color:#F5F1EA;
}

.project-window-label{
    font-size:13px;
    letter-spacing:4px;
    text-transform:uppercase;
    color:var(--muted);
    margin-bottom:18px;
}

.project-window h2{
    font-size:clamp(38px,5vw,62px);
    line-height:1;
    letter-spacing:-2px;
    margin-bottom:22px;
}

.project-window > p{
    font-size:20px;
    line-height:1.8;
    color:#3D3D3D;
    margin-bottom:30px;
}

.project-window-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
}

.project-window-grid span{
    min-height:120px;
    padding:18px;
    border-radius:12px;
    background:rgba(255,255,255,0.62);
    color:var(--ink);
    font-size:15px;
    line-height:1.65;
}

/* CONTACT UPGRADE */

.contact-page{
    --contact-mouse-x:50%;
    --contact-mouse-y:35%;
    isolation:isolate;
    background:
        linear-gradient(rgba(31,45,37,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(31,45,37,0.052) 1px, transparent 1px),
        linear-gradient(rgba(31,45,37,0.11) 1px, transparent 1px),
        linear-gradient(90deg, rgba(31,45,37,0.1) 1px, transparent 1px),
        radial-gradient(circle at 16% 20%, rgba(96,116,102,0.2), transparent 28%),
        radial-gradient(circle at 88% 24%, rgba(62,111,142,0.14), transparent 32%),
        linear-gradient(135deg, rgba(255,253,248,0.9), rgba(245,241,234,0.42)),
        var(--bg);
    background-size:36px 36px, 36px 36px, 180px 180px, 180px 180px, auto, auto, auto, auto;
}

.contact-page::before{
    width:920px;
    height:920px;
    right:-310px;
    top:20px;
    background:none;
    border:1px solid rgba(31,45,37,0.14);
    border-radius:50%;
    box-shadow:
        inset 0 0 0 90px rgba(31,45,37,0.018),
        inset 0 0 0 180px rgba(31,45,37,0.018),
        inset 0 0 0 270px rgba(31,45,37,0.018);
    filter:none;
    z-index:0;
}

.contact-page::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:0;
    pointer-events:none;
    background:
        radial-gradient(circle at var(--contact-mouse-x) var(--contact-mouse-y), rgba(31,45,37,0.18), transparent 18%),
        linear-gradient(115deg, transparent 0%, rgba(255,253,248,0.54) 42%, transparent 64%),
        repeating-linear-gradient(62deg, transparent 0 116px, rgba(31,45,37,0.09) 117px, transparent 119px),
        repeating-linear-gradient(-24deg, transparent 0 150px, rgba(31,45,37,0.07) 151px, transparent 153px);
    background-size:auto, auto, auto, auto;
    mix-blend-mode:multiply;
    opacity:0.78;
}

.contact-ambient-layer{
    position:absolute;
    inset:0;
    z-index:0;
    overflow:hidden;
    pointer-events:none;
}

.signal-node{
    position:absolute;
    width:14px;
    height:14px;
    border-radius:50%;
    background:#334D42;
    box-shadow:
        0 0 0 12px rgba(31,45,37,0.07),
        0 0 70px rgba(31,45,37,0.28);
    opacity:0.68;
    animation:signalPulse 4s ease-in-out infinite;
}

.node-one{
    top:24%;
    left:11%;
}

.node-two{
    top:17%;
    right:17%;
    animation-delay:0.7s;
}

.node-three{
    bottom:23%;
    left:18%;
    animation-delay:1.4s;
}

.node-four{
    bottom:16%;
    right:12%;
    animation-delay:2.1s;
}

.signal-thread{
    position:absolute;
    height:2px;
    width:34vw;
    background:linear-gradient(90deg, transparent, rgba(31,45,37,0.28), transparent);
    transform-origin:left center;
    opacity:0.75;
}

.thread-one{
    top:27%;
    left:11%;
    transform:rotate(13deg);
}

.thread-two{
    top:49%;
    right:10%;
    transform:rotate(-18deg);
}

.thread-three{
    bottom:25%;
    left:19%;
    transform:rotate(-9deg);
}

.contact-quote-field{
    position:absolute;
    inset:0;
    z-index:0;
    overflow:hidden;
    pointer-events:none;
    user-select:none;
    mask-image:linear-gradient(to bottom, transparent 0%, #000 9%, #000 88%, transparent 100%);
}

.quote-line{
    position:absolute;
    width:min(760px,calc(100% - 96px));
    max-width:none;
    font-size:clamp(18px,1.45vw,28px);
    line-height:1.45;
    letter-spacing:0;
    font-weight:500;
    color:rgba(31,45,37,0.68);
    text-transform:none;
    padding:14px 18px 14px 24px;
    border-left:3px solid rgba(31,45,37,0.42);
    border-radius:0 12px 12px 0;
    background:linear-gradient(90deg, rgba(255,253,248,0.78), rgba(255,253,248,0.16));
    backdrop-filter:blur(2px);
    box-shadow:0 18px 70px rgba(31,45,37,0.08);
    transform:rotate(-1.2deg);
    animation:quoteFloat 10s ease-in-out infinite;
}

.quote-line span{
    color:#1F2D25;
    font-weight:700;
    background:linear-gradient(transparent 58%, rgba(186,166,118,0.5) 58%);
    text-shadow:none;
}

.quote-line-one{
    top:150px;
    left:8vw;
    text-align:left;
}

.quote-line-two{
    top:300px;
    right:7vw;
    text-align:right;
    border-left:0;
    border-right:3px solid rgba(31,45,37,0.42);
    border-radius:12px 0 0 12px;
    background:linear-gradient(270deg, rgba(255,253,248,0.78), rgba(255,253,248,0.16));
    transform:rotate(1.2deg);
    animation-delay:-2s;
}

.quote-line-three{
    top:455px;
    left:18vw;
    text-align:center;
    transform:rotate(-0.8deg);
    animation-delay:-4s;
}

.quote-line-four{
    top:620px;
    left:6vw;
    text-align:left;
    transform:rotate(1deg);
    animation-delay:-6s;
}

.quote-line-five{
    bottom:320px;
    right:9vw;
    text-align:right;
    border-left:0;
    border-right:3px solid rgba(31,45,37,0.42);
    border-radius:12px 0 0 12px;
    background:linear-gradient(270deg, rgba(255,253,248,0.78), rgba(255,253,248,0.16));
    transform:rotate(-1deg);
    animation-delay:-8s;
}

.quote-line-six{
    bottom:180px;
    left:13vw;
    text-align:center;
    transform:rotate(0.8deg);
    animation-delay:-10s;
}

.quote-line-seven{
    top:56%;
    right:6vw;
    text-align:left;
    transform:rotate(-1.3deg);
    animation-delay:-12s;
}

@keyframes quoteFloat{
    0%{
        translate:0 0;
    }

    50%{
        translate:24px -12px;
    }

    100%{
        translate:0 0;
    }
}

@keyframes signalPulse{
    0%,
    100%{
        transform:scale(1);
        opacity:0.48;
    }

    50%{
        transform:scale(1.35);
        opacity:0.82;
    }
}

.contact-system-hero,
.contact-container.contact-system-grid{
    position:relative;
    z-index:2;
}

.contact-system-hero{
    padding:42px;
    border-radius:22px;
    background:rgba(245,241,234,0.5);
    border:1px solid rgba(31,45,37,0.08);
    backdrop-filter:blur(8px);
}

.contact-container.contact-system-grid{
    position:relative;
    z-index:2;
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:0.85fr 1.15fr;
    gap:28px;
}

.contact-signal-card,
.contact-compose-card{
    border-radius:18px;
    background:rgba(255,253,248,0.84);
    border:1px solid rgba(31,45,37,0.08);
    box-shadow:var(--shadow);
    backdrop-filter:blur(14px);
}

.contact-signal-card{
    padding:42px;
}

.contact-signal-card h2{
    font-size:clamp(34px,4vw,56px);
    line-height:1.08;
    letter-spacing:-2px;
    color:var(--ink);
    margin-bottom:32px;
}

.copy-email{
    width:100%;
    border:0;
    border-radius:14px;
    background:var(--ink);
    color:#F5F1EA;
    padding:20px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    cursor:pointer;
    font-size:16px;
    word-break:break-word;
    transition:0.3s ease;
}

.copy-email:hover{
    transform:translateY(-5px);
}

.contact-info{
    display:grid;
    gap:14px;
    margin-top:28px;
}

.contact-info a{
    min-height:58px;
    padding:0 18px;
    border-radius:100px;
    background:var(--surface);
    color:var(--ink);
    text-decoration:none;
    display:flex;
    align-items:center;
    gap:14px;
    transition:0.3s ease;
}

.contact-info a:hover{
    background:var(--ink);
    color:#F5F1EA;
    transform:translateX(6px);
}

.copy-feedback{
    min-height:26px;
    margin-top:18px;
    color:var(--muted);
}

.contact-compose-card{
    padding:42px;
}

.compose-top{
    display:flex;
    justify-content:space-between;
    gap:18px;
    align-items:center;
    margin-bottom:26px;
}

.compose-top span{
    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
}

.contact-form{
    display:grid;
    gap:18px;
}

.contact-form label{
    display:grid;
    gap:10px;
}

.contact-form label span{
    font-size:12px;
    letter-spacing:3px;
    text-transform:uppercase;
    color:var(--muted);
}

.contact-form input,
.contact-form textarea{
    width:100%;
    border:1px solid rgba(31,45,37,0.1);
    border-radius:14px;
    background:rgba(255,255,255,0.62);
    color:var(--ink);
    padding:18px 20px;
    font-size:17px;
    outline:none;
    transition:0.3s ease;
}

.contact-form textarea{
    min-height:190px;
    resize:vertical;
}

.contact-form input:focus,
.contact-form textarea:focus{
    border-color:var(--ink);
    box-shadow:0 0 0 4px rgba(31,45,37,0.08);
}

.contact-form button{
    min-height:58px;
    border:0;
    border-radius:100px;
    background:var(--ink);
    color:#F5F1EA;
    cursor:pointer;
    display:inline-flex;
    justify-content:center;
    align-items:center;
    gap:12px;
    font-size:13px;
    letter-spacing:3px;
    text-transform:uppercase;
    transition:0.3s ease;
}

.contact-form button:hover{
    transform:translateY(-5px);
}

/* DARK MODE EXTENSIONS */

.dark-mode .system-hero h1,
.dark-mode .contact-signal-card h2,
.dark-mode .project-content h2{
    color:#F5F5F5;
}

.dark-mode .system-hero p:not(.system-label),
.dark-mode .project-content p,
.dark-mode .project-window > p{
    color:#D6D6D6;
}

.dark-mode .experience-stat,
.dark-mode .experience-marker,
.dark-mode .experience-node .experience-content,
.dark-mode .project-card,
.dark-mode .project-filter,
.dark-mode .project-window,
.dark-mode .project-window-grid span,
.dark-mode .contact-signal-card,
.dark-mode .contact-compose-card,
.dark-mode .contact-info a,
.dark-mode .contact-form input,
.dark-mode .contact-form textarea{
    background:#1E1E1E;
    color:#F5F5F5;
    border-color:rgba(255,255,255,0.08);
}

.dark-mode .experience-tags span,
.dark-mode .project-close{
    background:#121212;
    color:#F5F5F5;
}

.dark-mode .experience-stat:hover,
.dark-mode .project-filter:hover,
.dark-mode .project-filter.active,
.dark-mode .contact-info a:hover{
    background:#F5F5F5;
    color:#121212;
}

.dark-mode .experience-stat:hover span,
.dark-mode .experience-stat:hover p{
    color:#121212;
}

.dark-mode .experience-stat span,
.dark-mode .experience-marker span,
.dark-mode .project-window h2,
.dark-mode .project-window-grid span{
    color:#F5F5F5;
}

.dark-mode .project-meta span,
.dark-mode .experience-meta span,
.dark-mode .contact-form label span,
.dark-mode .compose-top span,
.dark-mode .copy-feedback{
    color:#C9C9C9;
}

.dark-mode .contact-form input::placeholder,
.dark-mode .contact-form textarea::placeholder{
    color:#8C8C8C;
}

.dark-mode .contact-page{
    background:
        linear-gradient(rgba(255,255,255,0.045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.038) 1px, transparent 1px),
        linear-gradient(rgba(255,255,255,0.09) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px),
        radial-gradient(circle at 20% 12%, rgba(96,116,102,0.18), transparent 32%),
        radial-gradient(circle at 86% 28%, rgba(62,111,142,0.2), transparent 30%),
        #121212;
    background-size:36px 36px, 36px 36px, 180px 180px, 180px 180px, auto, auto, auto;
}

.dark-mode .contact-page::after{
    background:
        radial-gradient(circle at var(--contact-mouse-x) var(--contact-mouse-y), rgba(245,245,245,0.12), transparent 20%),
        linear-gradient(115deg, transparent 0%, rgba(255,255,255,0.05) 42%, transparent 64%),
        repeating-linear-gradient(62deg, transparent 0 116px, rgba(255,255,255,0.06) 117px, transparent 119px),
        repeating-linear-gradient(-24deg, transparent 0 150px, rgba(255,255,255,0.045) 151px, transparent 153px);
    background-size:auto, auto, auto, auto;
    mix-blend-mode:screen;
}

.dark-mode .quote-line{
    color:rgba(245,245,245,0.64);
    background:linear-gradient(90deg, rgba(30,30,30,0.74), rgba(18,18,18,0.16));
    border-color:rgba(255,255,255,0.08);
    box-shadow:0 30px 90px rgba(0,0,0,0.18);
}

.dark-mode .quote-line span{
    color:#F5F5F5;
    background:linear-gradient(transparent 58%, rgba(96,116,102,0.6) 58%);
    text-shadow:0 22px 70px rgba(245,245,245,0.08);
}

.dark-mode .signal-node{
    background:#F5F5F5;
    box-shadow:
        0 0 0 12px rgba(245,245,245,0.06),
        0 0 70px rgba(245,245,245,0.16);
}

.dark-mode .signal-thread{
    background:linear-gradient(90deg, transparent, rgba(245,245,245,0.14), transparent);
}

.dark-mode .contact-system-hero{
    background:rgba(18,18,18,0.48);
    border-color:rgba(255,255,255,0.08);
}

.dark-mode .about-page{
    background:
        radial-gradient(ellipse 600px 400px at 5% 12%, rgba(96,116,102,0.10) 0%, transparent 100%),
        radial-gradient(ellipse 400px 600px at 96% 38%, rgba(138,111,77,0.075) 0%, transparent 100%),
        radial-gradient(ellipse 700px 300px at 50% 72%, rgba(62,111,142,0.055) 0%, transparent 100%),
        radial-gradient(ellipse 300px 400px at 18% 88%, rgba(51,77,66,0.06) 0%, transparent 100%),
        repeating-linear-gradient(
            -52deg,
            transparent 0px,
            transparent 88px,
            rgba(255,255,255,0.018) 89px,
            rgba(255,255,255,0.018) 90px,
            transparent 91px,
            transparent 178px
        ),
        #121212;
}

.dark-mode .about-page::before{
    color:rgba(245,245,245,0.045);
}

.dark-mode .about-page::after{
    color:rgba(245,245,245,0.16);
}

/* Breathing ambient pulse on home hero — organic, no blocks */
.home-hero::before{
    content:"";
    position:absolute;
    width:900px;
    height:900px;
    border-radius:50%;
    left:-320px;
    top:-200px;
    background:radial-gradient(circle, rgba(31,45,37,0.05) 0%, rgba(96,116,102,0.028) 40%, transparent 70%);
    animation:homeAmbientPulse 14s ease-in-out infinite;
    pointer-events:none;
    z-index:0;
}

.home-hero::after{
    content:"";
    position:absolute;
    width:700px;
    height:700px;
    border-radius:50%;
    right:-220px;
    bottom:-150px;
    background:radial-gradient(circle, rgba(62,111,142,0.055) 0%, rgba(51,77,66,0.022) 44%, transparent 70%);
    animation:homeAmbientPulse 18s ease-in-out infinite reverse;
    pointer-events:none;
    z-index:0;
}

@keyframes homeAmbientPulse{
    0%, 100%{ transform:scale(1); opacity:1; }
    50%{ transform:scale(1.12); opacity:0.72; }
}

.dark-mode .home-hero::before{
    background:radial-gradient(circle, rgba(96,116,102,0.09) 0%, rgba(51,77,66,0.045) 40%, transparent 70%);
}

.dark-mode .home-hero::after{
    background:radial-gradient(circle, rgba(62,111,142,0.09) 0%, rgba(51,77,66,0.038) 44%, transparent 70%);
}

.dark-mode .experience-page{
    background:
        radial-gradient(ellipse 560px 420px at 6% 18%, rgba(96,116,102,0.10) 0%, transparent 100%),
        radial-gradient(ellipse 460px 560px at 94% 72%, rgba(51,77,66,0.08) 0%, transparent 100%),
        radial-gradient(ellipse 340px 340px at 50% 5%, rgba(62,111,142,0.06) 0%, transparent 100%),
        radial-gradient(ellipse 280px 480px at 82% 22%, rgba(138,111,77,0.05) 0%, transparent 100%),
        repeating-linear-gradient(
            0deg,
            transparent 0px,
            transparent 62px,
            rgba(255,255,255,0.024) 63px,
            rgba(255,255,255,0.024) 64px,
            transparent 65px
        ),
        repeating-linear-gradient(
            90deg,
            transparent 0px,
            transparent 194px,
            rgba(255,255,255,0.016) 195px,
            rgba(255,255,255,0.016) 196px,
            transparent 197px
        ),
        #121212;
}

.dark-mode .projects-page{
    background:
        radial-gradient(ellipse 500px 500px at 95% 5%, rgba(62,111,142,0.11) 0%, transparent 100%),
        radial-gradient(ellipse 420px 600px at 3% 95%, rgba(96,116,102,0.09) 0%, transparent 100%),
        radial-gradient(ellipse 600px 400px at 50% 50%, rgba(51,77,66,0.05) 0%, transparent 100%),
        radial-gradient(ellipse 300px 300px at 88% 85%, rgba(138,111,77,0.06) 0%, transparent 100%),
        radial-gradient(circle, rgba(255,255,255,0.055) 1px, transparent 1px),
        radial-gradient(circle, rgba(255,255,255,0.032) 1px, transparent 1px),
        #121212;
    background-size:
        auto, auto, auto, auto,
        38px 38px,
        19px 19px;
    background-position:
        0 0, 0 0, 0 0, 0 0,
        0 0,
        9.5px 9.5px;
}

/* INNER PAGE RESPONSIVE */

@media(max-width:1100px){
    .system-page{
        padding:190px 25px 80px;
    }

    .system-hero-grid,
    .contact-container.contact-system-grid{
        grid-template-columns:1fr;
        gap:36px;
    }

    .experience-dashboard,
    .projects-container.project-lab{
        grid-template-columns:1fr;
    }

    .project-image{
        height:340px;
    }

    .project-window-grid{
        grid-template-columns:1fr;
    }

    .quote-line{
        width:calc(100% - 50px);
        font-size:clamp(24px,4.8vw,44px);
        padding:18px 22px;
        max-width:none;
    }

    .quote-line-one,
    .quote-line-three,
    .quote-line-four,
    .quote-line-six{
        left:25px;
        right:auto;
    }

    .quote-line-two,
    .quote-line-five,
    .quote-line-seven{
        right:25px;
        left:auto;
    }
}

@media(max-width:600px){
    .system-page{
        padding-top:210px;
    }

    .system-hero h1{
        font-size:52px;
        letter-spacing:-3px;
    }

    .system-hero p:not(.system-label){
        font-size:18px;
    }

    .experience-node{
        grid-template-columns:1fr;
        gap:16px;
    }

    .experience-timeline::before{
        display:none;
    }

    .experience-marker{
        width:54px;
        height:54px;
    }

    .experience-node .experience-content,
    .contact-signal-card,
    .contact-compose-card,
    .project-window{
        padding:28px;
    }

    .experience-node .experience-content p,
    .project-window > p{
        font-size:17px;
    }

    .project-image{
        height:260px;
    }

    .copy-email{
        align-items:flex-start;
        flex-direction:column;
    }

    .contact-system-hero{
        padding:28px;
    }

    .quote-line{
        width:calc(100% - 32px);
        font-size:24px;
        line-height:1.08;
        letter-spacing:-0.5px;
        color:rgba(31,45,37,0.18);
        padding:14px 16px;
    }

    .quote-line span{
        color:rgba(31,45,37,0.48);
    }

    .quote-line-one,
    .quote-line-three,
    .quote-line-four,
    .quote-line-six{
        left:16px;
    }

    .quote-line-two,
    .quote-line-five,
    .quote-line-seven{
        right:16px;
    }

    .quote-line-one{
        top:160px;
    }

    .quote-line-two{
        top:305px;
    }

    .quote-line-three{
        top:455px;
    }

    .quote-line-four{
        top:610px;
    }

    .quote-line-five{
        bottom:310px;
    }

    .quote-line-six{
        bottom:155px;
    }
}