 :root {
      --white:    #f5f2ed;
      --paper:    #ede9e1;
      --ink:      #0e0e0e;
      --muted:    #7a7670;
      --border:   rgba(14,14,14,.1);
      --border-h: rgba(14,14,14,.22);
      --acc:      #e63222;
      --acc-lt:   #ff4433;
      --acc-pale: rgba(230,50,34,.07);
      --r: 3px;
    }
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body { background: var(--white); color: var(--ink); font-family: 'Fraunces', serif; font-weight: 300; line-height: 1.65; overflow-x: hidden; cursor: none; }
    ::-webkit-scrollbar { width: 3px; }
    ::-webkit-scrollbar-track { background: var(--paper); }
    ::-webkit-scrollbar-thumb { background: var(--acc); }
    a { color: inherit; text-decoration: none; }
    strong { font-weight: 700; color: var(--ink); }

    /* CURSOR */
    #cursor { position: fixed; z-index: 9999; pointer-events: none; width: 8px; height: 8px; border-radius: 50%; background: var(--acc); transform: translate(-50%,-50%); transition: transform .1s ease, width .25s, height .25s; }
    #cursor-ring { position: fixed; z-index: 9998; pointer-events: none; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--acc); transform: translate(-50%,-50%); transition: width .3s, height .3s, opacity .3s; opacity: .45; }

    /* NAV */
    nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; padding: 0 3rem; height: 60px; display: flex; align-items: center; justify-content: space-between; background: var(--white); border-bottom: 1px solid var(--border); transition: box-shadow .3s; }
    nav.raised { box-shadow: 0 2px 20px rgba(0,0,0,.06); }
    .nav-logo { font-family: 'Bebas Neue', sans-serif; font-size: 1.45rem; letter-spacing: .12em; color: var(--ink); line-height: 1; }
    .nav-logo span { color: var(--acc); }
    .nav-links { display: flex; gap: 2rem; list-style: none; align-items: center; }
    .nav-links a { font-family: 'DM Mono', monospace; font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); transition: color .25s; }
    .nav-links a:hover { color: var(--ink); }
    .nav-cta { background: var(--ink) !important; color: var(--white) !important; padding: .45rem 1.1rem; border-radius: var(--r); transition: background .25s !important; }
    .nav-cta:hover { background: var(--acc) !important; }

    /* ── HERO ── */
    #hero {
      min-height: 82vh;
      padding-top: 60px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      border-bottom: 1px solid var(--border);
      overflow: hidden;
      position: relative;
    }
    /* abstract radial background */
    #hero::before {
      content: '';
      position: absolute; inset: 0; z-index: 0; pointer-events: none;
      background:
        radial-gradient(ellipse 55% 70% at 78% 50%, rgba(230,50,34,.06) 0%, transparent 65%),
        radial-gradient(ellipse 35% 45% at 92% 8%,  rgba(14,14,14,.04)  0%, transparent 55%),
        radial-gradient(ellipse 28% 45% at 8%  92%, rgba(230,50,34,.03) 0%, transparent 60%);
    }
    /* subtle grid overlay — right half only */
    #hero::after {
      content: '';
      position: absolute; top: 0; right: 0; bottom: 0; width: 50%; z-index: 0; pointer-events: none;
      background-image: linear-gradient(rgba(14,14,14,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(14,14,14,.045) 1px, transparent 1px);
      background-size: 44px 44px;
      mask-image: radial-gradient(ellipse 90% 80% at 60% 50%, black 0%, transparent 75%);
    }
    .hero-left {
      padding: 2.5rem 3rem 3rem;
      display: flex; flex-direction: column; justify-content: space-between;
      border-right: 1px solid var(--border);
      position: relative; z-index: 1;
    }
    .hero-eyebrow {
      font-family: 'DM Mono', monospace; font-size: .65rem; letter-spacing: .2em; text-transform: uppercase;
      color: var(--muted); display: flex; align-items: center; gap: .7rem;
    }
    .hero-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--acc); }
    .hero-h1-wrap { flex: 1; display: flex; align-items: center; padding: 1.5rem 0; }
    h1 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(3.2rem, 6.5vw, 6.5rem); line-height: .92; letter-spacing: .02em; color: var(--ink); }
    h1 .acc { color: var(--acc); }
    h1 .italic { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: .7em; }
    .hero-tagline { font-size: .95rem; color: var(--muted); font-style: italic; max-width: 380px; line-height: 1.6; }

    /* hero right */
    .hero-right { display: flex; flex-direction: column; position: relative; z-index: 1; }
    .hero-graphic { flex: 1; display: flex; align-items: center; justify-content: center; padding: 1rem; overflow: hidden; }
    .hero-graphic svg { width: 100%; max-width: 410px; height: auto; }

    /* single-row stats */
    .hero-stats { display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid var(--border); }
    .hstat { padding: 1rem 1.2rem; border-right: 1px solid var(--border); }
    .hstat:last-child { border-right: none; }
    .hstat-n { font-family: 'Bebas Neue', sans-serif; font-size: 1.9rem; line-height: 1; color: var(--ink); margin-bottom: .18rem; }
    .hstat-n span { color: var(--acc); font-size: .65em; }
    .hstat-l { font-family: 'DM Mono', monospace; font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
    .hero-scroll { padding: 1rem 1.5rem; display: flex; align-items: center; gap: 1rem; border-top: 1px solid var(--border); }
    .scroll-line { width: 40px; height: 1px; background: var(--ink); animation: scrollpulse 2s ease-in-out infinite; }
    @keyframes scrollpulse { 0%,100%{width:40px;opacity:.4} 50%{width:70px;opacity:1} }
    .scroll-text { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted); }

    /* orbit ring animation */
    #orbit-ring { transform-origin: 180px 160px; animation: orbit-spin 18s linear infinite; }
    @keyframes orbit-spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }

    /* MARQUEE */
    .marquee-strip { background: var(--ink); padding: .75rem 0; overflow: hidden; border-bottom: 1px solid rgba(255,255,255,.08); }
    .marquee-track { display: flex; gap: 3rem; animation: marquee 28s linear infinite; white-space: nowrap; }
    .marquee-track span { font-family: 'DM Mono', monospace; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.35); }
    .marquee-track span.acc { color: var(--acc); }
    @keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

    /* COMMON */
    section { padding: 6rem 3rem; }
    .sec-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 4rem; padding-bottom: 1.5rem; border-bottom: 1px solid var(--border); flex-wrap: wrap; gap: 1rem; }
    .sec-label { font-family: 'DM Mono', monospace; font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--acc); margin-bottom: .6rem; }
    h2 { font-family: 'Bebas Neue', sans-serif; font-size: clamp(2.5rem,5vw,4.5rem); letter-spacing: .03em; line-height: .95; color: var(--ink); }
    h2 em { font-family: 'Fraunces', serif; font-style: italic; font-weight: 300; font-size: .75em; letter-spacing: 0; }
    .sec-desc { max-width: 380px; font-size: .92rem; color: var(--muted); line-height: 1.7; }
    .btn { display: inline-flex; align-items: center; gap: .5rem; padding: .7rem 1.6rem; border-radius: var(--r); font-family: 'DM Mono', monospace; font-size: .67rem; letter-spacing: .1em; text-transform: uppercase; transition: all .25s; cursor: pointer; border: none; }
    .btn-dark { background: var(--ink); color: var(--white); }
    .btn-dark:hover { background: var(--acc); }
    .btn-outline { background: transparent; color: var(--ink); border: 1px solid var(--border-h); }
    .btn-outline:hover { border-color: var(--acc); color: var(--acc); }
    .reveal { opacity: 0; transform: translateY(20px); transition: opacity .6s ease, transform .6s ease; }
    .reveal.visible { opacity: 1; transform: none; }
    .d1{transition-delay:.08s;} .d2{transition-delay:.16s;} .d3{transition-delay:.24s;}

    /* ABOUT */
    #about { background: var(--white); display: grid; grid-template-columns: 1fr 1.6fr; gap: 0; padding: 0; border-bottom: 1px solid var(--border); }
    .about-left { padding: 5rem 3rem; border-right: 1px solid var(--border); display: flex; flex-direction: column; gap: 2rem; }
    .about-right { padding: 5rem 4rem; }
    .about-right p { font-size: .97rem; color: var(--muted); line-height: 1.85; margin-bottom: 1.2rem; }
    .cert-item { display: flex; align-items: center; gap: .8rem; padding: .7rem 1rem; background: var(--paper); border-radius: var(--r); font-size: .84rem; color: var(--muted); transition: background .2s, color .2s; margin-bottom: .4rem; }
    .cert-item:hover { background: var(--ink); color: var(--white); }
    .cert-icon { font-size: 1rem; flex-shrink: 0; }
    .cert-name { flex: 1; }
    .cert-issuer { font-family: 'DM Mono', monospace; font-size: .58rem; letter-spacing: .1em; text-transform: uppercase; color: var(--acc); opacity: .85; white-space: nowrap; }

    /* SKILLS */
    #skills { background: var(--paper); border-bottom: 1px solid var(--border); }
    .skills-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
    .skill-group { background: var(--white); padding: 2rem; transition: background .25s; }
    .skill-group:hover { background: var(--ink); }
    .skill-group:hover .sg-title { color: var(--white); }
    .skill-group:hover .sg-item { color: rgba(255,255,255,.55); border-color: rgba(255,255,255,.1); }
    .skill-group:hover .sg-icon { filter: brightness(3); }
    .sg-icon { font-size: 1.6rem; margin-bottom: 1rem; display: block; transition: filter .25s; }
    .sg-title { font-family: 'Bebas Neue', sans-serif; font-size: 1.3rem; letter-spacing: .06em; color: var(--ink); margin-bottom: 1rem; transition: color .25s; }
    .sg-items { display: flex; flex-direction: column; gap: .35rem; }
    .sg-item { font-family: 'DM Mono', monospace; font-size: .63rem; letter-spacing: .07em; color: var(--muted); padding: .28rem 0; border-bottom: 1px solid var(--border); transition: color .25s, border-color .25s; }
    .sg-item:last-child { border-bottom: none; }

    /* TOOLS */
    #tools { background: var(--white); border-bottom: 1px solid var(--border); }
    .tools-section { margin-bottom: 2.5rem; }
    .tools-section-title { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-bottom: .8rem; display: flex; align-items: center; gap: .6rem; }
    .tools-section-title::before { content: ''; width: 16px; height: 1px; background: var(--acc); }
    .tools-wrap { display: flex; flex-wrap: wrap; gap: .5rem; }
    .tool-chip { display: flex; align-items: center; gap: .5rem; padding: .55rem 1.1rem; background: var(--paper); border: 1px solid var(--border); border-radius: 100px; font-family: 'DM Mono', monospace; font-size: .65rem; letter-spacing: .08em; color: var(--muted); transition: all .22s; }
    .tool-chip:hover { background: var(--ink); color: var(--white); border-color: var(--ink); }
    .tc-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--acc); flex-shrink: 0; }

    /* EXPERIENCE */
    #experience { background: var(--ink); border-bottom: 1px solid rgba(255,255,255,.06); }
    #experience .sec-label { color: var(--acc); }
    #experience h2 { color: var(--white); }
    #experience .sec-desc { color: rgba(255,255,255,.4); }
    #experience .sec-head { border-bottom-color: rgba(255,255,255,.08); }
    .exp-list { display: flex; flex-direction: column; }
    .exp-item { display: grid; grid-template-columns: 200px 1fr auto; gap: 2rem; align-items: start; padding: 2rem 0; border-bottom: 1px solid rgba(255,255,255,.06); position: relative; transition: padding-left .3s; }
    .exp-item:hover { padding-left: 1rem; }
    .exp-item:hover .exp-accent { opacity: 1; }
    .exp-accent { position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--acc); opacity: 0; transition: opacity .3s; }
    .exp-item:last-child { border-bottom: none; }
    .exp-period { font-family: 'DM Mono', monospace; font-size: .68rem; letter-spacing: .1em; color: rgba(255,255,255,.3); padding-top: .25rem; }
    .exp-period .years { display: block; color: var(--acc); font-size: .62rem; margin-top: .2rem; }
    .exp-role { font-family: 'Fraunces', serif; font-size: 1.35rem; font-weight: 400; color: var(--white); margin-bottom: .35rem; }
    .exp-company { font-family: 'DM Mono', monospace; font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--acc); margin-bottom: .6rem; }
    .exp-desc { font-size: .86rem; color: rgba(255,255,255,.4); line-height: 1.7; }
    .exp-tags { display: flex; gap: .35rem; flex-wrap: wrap; margin-top: .7rem; }
    .exp-tag { font-family: 'DM Mono', monospace; font-size: .57rem; letter-spacing: .08em; text-transform: uppercase; padding: .18rem .55rem; border-radius: 2px; border: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.35); }
    .exp-duration { font-family: 'Bebas Neue', sans-serif; font-size: 2.4rem; color: rgba(255,255,255,.07); letter-spacing: .06em; white-space: nowrap; padding-top: .1rem; }

    /* SERVICES */
    #services { background: var(--paper); border-bottom: 1px solid var(--border); }
    .services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
    .svc-card { background: var(--white); padding: 2.5rem; display: flex; flex-direction: column; position: relative; overflow: hidden; transition: background .3s; }
    .svc-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: var(--acc); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; }
    .svc-card:hover { background: var(--ink); }
    .svc-card:hover::after { transform: scaleX(1); }
    .svc-card:hover .svc-num { color: rgba(255,255,255,.05); }
    .svc-card:hover .svc-title { color: var(--white); }
    .svc-card:hover .svc-desc { color: rgba(255,255,255,.45); }
    .svc-card:hover .svc-tag { border-color: rgba(255,255,255,.12); color: rgba(255,255,255,.35); }
    .svc-num { font-family: 'Bebas Neue', sans-serif; font-size: 4.5rem; line-height: 1; color: rgba(14,14,14,.05); position: absolute; top: 1rem; right: 1.5rem; transition: color .3s; }
    .svc-icon { font-size: 1.8rem; margin-bottom: 1.5rem; }
    .svc-title { font-family: 'Fraunces', serif; font-size: 1.4rem; font-weight: 400; color: var(--ink); margin-bottom: .7rem; position: relative; z-index: 1; transition: color .3s; }
    .svc-desc { font-size: .84rem; color: var(--muted); line-height: 1.7; position: relative; z-index: 1; flex: 1; margin-bottom: 1.5rem; transition: color .3s; }
    .svc-tags { display: flex; flex-wrap: wrap; gap: .3rem; position: relative; z-index: 1; }
    .svc-tag { font-family: 'DM Mono', monospace; font-size: .57rem; letter-spacing: .08em; padding: .18rem .55rem; border-radius: 2px; border: 1px solid var(--border-h); color: var(--muted); transition: all .3s; }

    /* CONTACT */
    #contact { background: var(--ink); display: grid; grid-template-columns: 1fr 1fr; min-height: 60vh; }
    .contact-left { padding: 6rem 3rem; border-right: 1px solid rgba(255,255,255,.06); display: flex; flex-direction: column; justify-content: space-between; }
    .contact-left h2 { color: var(--white); font-size: clamp(2.5rem,5vw,4.5rem); }
    .contact-left h2 em { color: var(--acc); }
    .contact-sub { font-size: .95rem; color: rgba(255,255,255,.4); line-height: 1.75; max-width: 360px; margin-top: 1.5rem; }
    .contact-detail { display: flex; flex-direction: column; gap: 1rem; margin-top: 3rem; }
    .cd-item { display: flex; align-items: center; gap: 1rem; padding: 1rem 1.2rem; background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07); border-radius: var(--r); transition: background .25s, border-color .25s; }
    .cd-item:hover { background: rgba(255,255,255,.07); border-color: rgba(255,255,255,.15); }
    .cd-icon { font-size: 1.2rem; flex-shrink: 0; }
    .cd-label { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.3); margin-bottom: .15rem; }
    .cd-val { font-size: .88rem; color: rgba(255,255,255,.7); }
    .contact-ref { padding: .7rem 1rem; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); border-radius: var(--r); font-family: 'DM Mono', monospace; font-size: .62rem; letter-spacing: .08em; color: rgba(255,255,255,.3); }
    .contact-ref a { color: var(--acc); }
    .contact-right { padding: 6rem 3rem; display: flex; flex-direction: column; gap: 1.2rem; }
    .contact-right h3 { font-family: 'Bebas Neue', sans-serif; font-size: 1.5rem; letter-spacing: .08em; color: rgba(255,255,255,.6); margin-bottom: 1rem; }
    .form-group { display: flex; flex-direction: column; gap: .4rem; }
    .form-label { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.3); }
    .form-input, .form-textarea { background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r); padding: .85rem 1.1rem; font-family: 'Fraunces', serif; font-size: .92rem; color: var(--white); outline: none; transition: border-color .25s, background .25s; }
    .form-input:focus, .form-textarea:focus { border-color: var(--acc); background: rgba(255,255,255,.07); }
    .form-input::placeholder, .form-textarea::placeholder { color: rgba(255,255,255,.2); }
    .form-textarea { resize: vertical; min-height: 110px; }
    .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
    .form-submit { background: var(--acc); color: var(--white); border: none; border-radius: var(--r); padding: .9rem 2rem; font-family: 'DM Mono', monospace; font-size: .7rem; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; transition: background .25s; align-self: flex-start; }
    .form-submit:hover { background: var(--acc-lt); }

    /* FOOTER */
    footer { background: var(--ink); border-top: 1px solid rgba(255,255,255,.06); padding: 1.5rem 3rem; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1rem; }
    .footer-logo { font-family: 'Bebas Neue', sans-serif; font-size: 1.2rem; letter-spacing: .1em; color: rgba(255,255,255,.5); }
    .footer-logo span { color: var(--acc); }
    .footer-links { display: flex; gap: 1.5rem; list-style: none; }
    .footer-links a { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.3); transition: color .25s; }
    .footer-links a:hover { color: var(--acc); }
    .footer-copy { font-family: 'DM Mono', monospace; font-size: .6rem; letter-spacing: .08em; color: rgba(255,255,255,.25); }

    /* RESPONSIVE */
    @media(max-width:1024px){ .skills-grid{grid-template-columns:1fr 1fr;} }
    @media(max-width:900px){
      nav{padding:0 1.5rem;} .nav-links{display:none;}
      #hero{grid-template-columns:1fr;min-height:auto;}
      .hero-left{padding:2rem 1.5rem 2.5rem;border-right:none;border-bottom:1px solid var(--border);}
      .hero-graphic{min-height:200px;}
      .hero-stats{grid-template-columns:repeat(4,1fr);}
      #about{grid-template-columns:1fr;}
      .about-left{border-right:none;border-bottom:1px solid var(--border);padding:3rem 1.5rem;}
      .about-right{padding:3rem 1.5rem;}
      section{padding:4rem 1.5rem;}
      .skills-grid{grid-template-columns:1fr 1fr;}
      .services-grid{grid-template-columns:1fr;}
      .exp-item{grid-template-columns:1fr;gap:.5rem;} .exp-duration{display:none;}
      #contact{grid-template-columns:1fr;}
      .contact-left{border-right:none;border-bottom:1px solid rgba(255,255,255,.06);padding:4rem 1.5rem;}
      .contact-right{padding:3rem 1.5rem;}
      footer{flex-direction:column;text-align:center;padding:1.5rem;}
      body{cursor:auto;} #cursor,#cursor-ring{display:none;}
    }
    @media(max-width:600px){
      .skills-grid{grid-template-columns:1fr;} .form-row{grid-template-columns:1fr;}
      .hero-stats{grid-template-columns:1fr 1fr;} .hstat{padding:.7rem .8rem;}
    }