/* ─── TOKENS ─── */
    :root {
      --bg:       #f5f2eb;
      --surface:  #eae6dc;
      --border:   rgba(20,18,16,.12);
      --muted:    #b8b0a4;
      --text:     #141210;
      --dim:      #877f72;
      --accent:   #e84b1a;          /* burnt orange */
      --accent2:  #b8e000;          /* electric lime */
      --accent3:  #0a5eff;          /* royal blue */
      --font-display: 'Syne', sans-serif;
      --font-mono:    'IBM Plex Mono', monospace;
      --font-serif:   'Instrument Serif', serif;
      /* ─── Custom easing curves ─── */
      --ease-out:     cubic-bezier(0.23, 1, 0.32, 1);
      --ease-in-out:  cubic-bezier(0.77, 0, 0.175, 1);
    }

    /* ─── RESET ─── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; font-size: 16px; }
    body {
      background: var(--bg);
      color: var(--text);
      font-family: var(--font-mono);
      font-weight: 300;
      overflow-x: hidden;
      cursor: none;
    }
    a { color: inherit; text-decoration: none; }
    img { display: block; max-width: 100%; }

    /* ─── CURSOR ─── */
    #cursor {
      position: fixed; width: 12px; height: 12px;
      background: var(--accent); border-radius: 50%;
      pointer-events: none; z-index: 9999;
      transform: translate(-50%,-50%);
      transition: transform .15s, width .2s, height .2s, background .2s;
    }
    #cursor-ring {
      position: fixed; width: 40px; height: 40px;
      border: 1.5px solid rgba(232,75,26,.4);
      border-radius: 50%; pointer-events: none; z-index: 9998;
      transform: translate(-50%,-50%);
      transition: width 350ms var(--ease-out), height 350ms var(--ease-out), border-color 200ms ease;
    }
    body:hover #cursor { }
    a:hover ~ #cursor, button:hover ~ #cursor { width: 20px; height: 20px; }

    /* ─── NAV ─── */
    nav {
      position: fixed; top: 0; left: 0; right: 0; z-index: 100;
      display: flex; align-items: center; justify-content: space-between;
      padding: 1.25rem 3rem;
      background: linear-gradient(to bottom, rgba(245,242,235,0.95) 0%, transparent 100%);
      backdrop-filter: blur(4px);
    }
    .nav-logo {
      font-family: var(--font-display);
      font-weight: 800; font-size: .9rem;
      letter-spacing: .08em; color: var(--accent);
      text-transform: uppercase;
    }
    .nav-links { display: flex; gap: 2.5rem; list-style: none; }
    .nav-links a {
      font-size: .72rem; letter-spacing: .12em; text-transform: uppercase;
      color: var(--dim); transition: color .2s; position: relative;
    }
    .nav-links a::after {
      content: ''; position: absolute; bottom: -4px; left: 0;
      width: 0; height: 1px; background: var(--accent); transition: width .25s;
    }
    .nav-links a:hover { color: var(--text); }
    .nav-links a:hover::after { width: 100%; }

    /* ─── NOISE OVERLAY ─── */
    body::before {
      content: '';
      position: fixed; inset: 0; z-index: 1; pointer-events: none;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
      opacity: .025;
    }

    /* ─── SECTIONS WRAPPER ─── */
    section { position: relative; z-index: 2; }

    /* ─── HERO ─── */
    #hero {
      min-height: 100vh;
      display: flex; flex-direction: column; justify-content: flex-end;
      padding: 0 3rem 5rem; overflow: hidden;
    }
    .hero-bg-grid {
      position: absolute; inset: 0; z-index: 0;
      background-image:
        linear-gradient(rgba(232,75,26,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(232,75,26,.04) 1px, transparent 1px);
      background-size: 60px 60px;
      mask-image: radial-gradient(ellipse 80% 60% at 50% 100%, black 30%, transparent 100%);
    }
    .hero-glow {
      position: absolute; bottom: -10%; left: 10%;
      width: 600px; height: 400px;
      background: radial-gradient(ellipse, rgba(10,94,255,.1) 0%, transparent 70%);
      pointer-events: none;
    }
    .hero-glow-2 {
      position: absolute; top: 20%; right: 5%;
      width: 300px; height: 300px;
      background: radial-gradient(ellipse, rgba(232,75,26,.08) 0%, transparent 70%);
      pointer-events: none;
    }
    .hero-tag {
      font-size: .72rem; letter-spacing: .18em; text-transform: uppercase;
      color: var(--accent); margin-bottom: 1.5rem;
      display: flex; align-items: center; gap: .75rem;
      animation: fadeUp .6s var(--ease-out) both;
    }
    .hero-title {
      font-family: var(--font-display); font-weight: 800;
      font-size: clamp(2.6rem, 9vw, 9rem);
      line-height: .95; letter-spacing: -.02em; text-transform: uppercase;
      animation: fadeUp .6s .08s var(--ease-out) both;
    }
    .hero-title .line-2 { color: transparent; -webkit-text-stroke: 1px rgba(20,18,16,.25); }
    .hero-title .line-accent { color: var(--accent); -webkit-text-stroke: 0; }
    .hero-sub {
      display: flex; align-items: flex-start; gap: 4rem;
      margin-top: 2.5rem; animation: fadeUp .6s .16s var(--ease-out) both;
    }
    .hero-desc { max-width: 400px; font-size: .9rem; line-height: 1.75; color: var(--dim); }
    .hero-desc strong { color: var(--text); font-weight: 400; }
    .hero-stats { display: flex; gap: 3rem; }
    .hero-stat-num {
      font-family: var(--font-display); font-weight: 800; font-size: 2.2rem;
      color: var(--text); line-height: 1;
    }
    .hero-stat-num span { color: var(--accent); }
    .hero-stat-label { font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); margin-top: .3rem; }
    .scroll-hint {
      position: absolute; right: 3rem; bottom: 5rem;
      display: flex; flex-direction: column; align-items: center; gap: .5rem;
      font-size: .65rem; letter-spacing: .15em; text-transform: uppercase; color: var(--muted);
      animation: fadeUp .6s .4s var(--ease-out) both;
    }
    .scroll-line { width: 1px; height: 60px; background: linear-gradient(to bottom, var(--muted), transparent); animation: scrollPulse 2s ease infinite; }

    /* ─── SECTION HEADER ─── */
    .section-header { display: flex; align-items: baseline; gap: 1.5rem; margin-bottom: 4rem; }
    .section-num { font-size: .7rem; letter-spacing: .15em; color: var(--accent); text-transform: uppercase; font-family: var(--font-mono); }
    .section-title { font-family: var(--font-display); font-weight: 800; font-size: clamp(2rem, 4vw, 3.5rem); text-transform: uppercase; letter-spacing: -.01em; }
    .section-line { flex: 1; height: 1px; background: linear-gradient(to right, var(--border), transparent); }

    /* ─── ABOUT ─── */
    #about { padding: 8rem 3rem; display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }
    .about-text p { font-size: .95rem; line-height: 1.9; color: var(--dim); margin-bottom: 1.2rem; }
    .about-text p strong { color: var(--text); font-weight: 400; }
    .about-text p em { color: var(--accent); font-style: italic; font-family: var(--font-serif); }
    .about-skills { margin-top: 2.5rem; display: flex; flex-wrap: wrap; gap: .6rem; }
    .skill-tag { font-size: .7rem; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--border); padding: .4rem .9rem; color: var(--dim); transition: border-color 150ms ease-out, color 150ms ease-out; }
    .skill-tag:hover { border-color: var(--accent); color: var(--accent); }
    .about-visual { position: relative; }
    .about-card { background: var(--surface); border: 1px solid var(--border); padding: 2.5rem; position: relative; overflow: hidden; }
    .about-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--accent3), var(--accent), var(--accent2)); }
    .about-card-label { font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 1rem; }
    .about-card-name { font-family: var(--font-display); font-weight: 700; font-size: 1.8rem; line-height: 1.1; margin-bottom: .5rem; }
    .about-card-role { font-size: .8rem; color: var(--dim); margin-bottom: 2rem; line-height: 1.6; }
    .about-card-info { display: flex; flex-direction: column; gap: .8rem; }
    .about-card-row { display: flex; justify-content: space-between; align-items: center; font-size: .72rem; padding-bottom: .8rem; border-bottom: 1px solid var(--border); }
    .about-card-row:last-child { border-bottom: none; padding-bottom: 0; }
    .about-card-row .label { color: var(--muted); letter-spacing: .08em; }
    .about-card-row .value { color: var(--text); text-align: right; }
    .status-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: var(--accent2); margin-right: .4rem; animation: blink 2.5s ease infinite; }
    .corner-deco { position: absolute; bottom: 0; right: 0; width: 40px; height: 40px; border-top: 1px solid var(--border); border-left: 1px solid var(--border); pointer-events: none; }

    /* ─── RESEARCH ─── */
    #research { padding: 6rem 3rem; background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .research-grid { display: grid; gap: 1px; background: var(--border); }
    .pub-item { background: var(--surface); padding: 2rem 2.5rem; display: grid; grid-template-columns: auto 1fr auto; gap: 2rem; align-items: start; transition: background .2s; position: relative; overflow: hidden; }
    .pub-item::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--accent); transform: scaleY(0); transform-origin: bottom; transition: transform .3s; }
    .pub-item:hover { background: #e2ddd4; }
    .pub-item:hover::before { transform: scaleY(1); }
    .pub-year { font-size: .7rem; letter-spacing: .1em; color: var(--muted); padding-top: .2rem; white-space: nowrap; }
    .pub-body {}
    .pub-title { font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.4; color: var(--text); margin-bottom: .5rem; }
    .pub-authors { font-size: .72rem; color: var(--muted); margin-bottom: .4rem; }
    .pub-authors strong { color: var(--accent); font-weight: 400; }
    .pub-venue { font-size: .7rem; color: var(--accent3); letter-spacing: .05em; }
    .pub-badge { font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; padding: .25rem .6rem; border: 1px solid; white-space: nowrap; height: fit-content; margin-top: .2rem; }
    .pub-badge.best   { border-color: var(--accent2); color: var(--accent2); }
    .pub-badge.oral   { border-color: var(--accent);  color: var(--accent); }
    .pub-badge.poster { border-color: var(--accent3); color: var(--accent3); }

    /* ─── PROJECTS ─── */
    #projects { padding: 6rem 3rem; }
    .projects-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 1px; background: var(--border); }
    .proj-card { background: var(--bg); padding: 2.5rem; position: relative; overflow: hidden; transition: background .25s; }
    .proj-card:hover { background: var(--surface); }
    .proj-card.wide   { grid-column: span 4; }
    .proj-card.narrow { grid-column: span 4; }
    .proj-card.full   { grid-column: span 12; }
    .proj-card.third  { grid-column: span 4; }
    .proj-num { font-size: .65rem; letter-spacing: .18em; color: var(--muted); margin-bottom: 1.5rem; }
    .proj-title { font-family: var(--font-display); font-weight: 700; font-size: 1.4rem; line-height: 1.15; margin-bottom: .8rem; transition: color .2s; }
    .proj-card:hover .proj-title { color: var(--accent); }
    .proj-desc { font-size: .78rem; line-height: 1.8; color: var(--dim); margin-bottom: 1.5rem; }
    .proj-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: 1.5rem; }
    .proj-tag { font-size: .6rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); border: 1px solid var(--border); padding: .2rem .5rem; }
    .proj-link { font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); display: flex; align-items: center; gap: .4rem; transition: gap .2s; }
    .proj-card:hover .proj-link { gap: .7rem; }
    .proj-arrow { width: 18px; height: 1px; background: var(--accent); position: relative; }
    .proj-arrow::after { content: ''; position: absolute; right: 0; top: -3px; width: 6px; height: 6px; border-top: 1px solid var(--accent); border-right: 1px solid var(--accent); transform: rotate(45deg); }
    .proj-accent-line { position: absolute; top: 0; left: 0; right: 0; height: 1.5px; }
    .proj-card:nth-child(1) .proj-accent-line { background: var(--accent); }
    .proj-card:nth-child(2) .proj-accent-line { background: var(--accent2); }
    .proj-card:nth-child(3) .proj-accent-line { background: var(--accent3); }
    .proj-card:nth-child(4) .proj-accent-line { background: var(--accent); }
    .proj-card:nth-child(5) .proj-accent-line { background: var(--accent2); }

    /* ─── HOBBIES ─── */
    #hobbies { padding: 6rem 3rem; background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .hobbies-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; margin-top: 1rem; }
    .hobby-card { border: 1px solid var(--border); padding: 2rem; position: relative; transition: border-color 180ms ease-out; }
    @media (hover: hover) and (pointer: fine) {
      .hobby-card { transition: border-color 180ms ease-out, transform 200ms var(--ease-out); }
      .hobby-card:hover { border-color: var(--accent); transform: translateY(-4px); }
    }
    .hobby-icon { font-size: 2rem; margin-bottom: 1.2rem; line-height: 1; }
    .hobby-name { font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; margin-bottom: .6rem; text-transform: uppercase; letter-spacing: .02em; }
    .hobby-desc { font-size: .78rem; line-height: 1.75; color: var(--dim); }
    .hobby-corner { position: absolute; bottom: -.5px; right: -.5px; width: 20px; height: 20px; border-top: 1px solid var(--accent); border-left: 1px solid var(--accent); opacity: 0; transition: opacity .2s; }
    .hobby-card:hover .hobby-corner { opacity: 1; }

    /* ─── CV ─── */
    #cv { padding: 6rem 3rem; display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center; }
    .cv-text .section-header { margin-bottom: 2rem; }
    .cv-desc { font-size: .88rem; line-height: 1.85; color: var(--dim); margin-bottom: 2.5rem; }
    .btn-primary {
      display: inline-flex; align-items: center; gap: .8rem;
      font-family: var(--font-mono); font-size: .72rem; letter-spacing: .15em; text-transform: uppercase;
      background: var(--accent); color: #faf8f3; padding: .9rem 2rem; font-weight: 500;
      transition: background 150ms ease-out, transform 150ms ease-out; border: none; cursor: none;
    }
    .btn-primary:hover { background: var(--text); transform: translateX(4px); }
    .btn-primary:active { transform: translateX(2px); transition-duration: 80ms; }
    .btn-secondary {
      display: inline-flex; align-items: center; gap: .8rem;
      font-family: var(--font-mono); font-size: .72rem; letter-spacing: .15em; text-transform: uppercase;
      border: 1px solid var(--border); color: var(--dim); padding: .9rem 2rem;
      transition: border-color 150ms ease-out, color 150ms ease-out; background: none; cursor: none;
    }
    .btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
    .btn-secondary:active { opacity: .7; transition-duration: 80ms; }
    .cv-timeline { position: relative; padding-left: 1.5rem; }
    .cv-timeline::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 1px; background: var(--border); }
    .cv-item { position: relative; margin-bottom: 2.5rem; }
    .cv-item::before { content: ''; position: absolute; left: -1.95rem; top: .4rem; width: 8px; height: 8px; border: 1px solid var(--accent); background: var(--bg); }
    .cv-item-year { font-size: .65rem; letter-spacing: .15em; color: var(--accent); text-transform: uppercase; margin-bottom: .3rem; }
    .cv-item-title { font-family: var(--font-display); font-weight: 600; font-size: .95rem; margin-bottom: .2rem; }
    .cv-item-sub { font-size: .75rem; color: var(--dim); }

    /* ─── CONTACT ─── */
    #contact { padding: 6rem 3rem 4rem; border-top: 1px solid var(--border); }
    .contact-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: start; }
    .contact-big { font-family: var(--font-display); font-weight: 800; font-size: clamp(3rem, 6vw, 6rem); text-transform: uppercase; line-height: .95; letter-spacing: -.02em; }
    .contact-big span { color: var(--accent); display: block; }
    .contact-right {}
    .contact-links { display: flex; flex-direction: column; gap: 1.5rem; margin-top: 2rem; }
    .contact-link {
      display: flex; align-items: center; justify-content: space-between;
      padding: 1.2rem 0; border-bottom: 1px solid var(--border);
      font-size: .8rem; letter-spacing: .08em; color: var(--dim); text-transform: uppercase;
      transition: color 180ms ease-out, border-bottom-color 180ms ease-out; position: relative; overflow: hidden;
    }
    .contact-link::before { content: ''; position: absolute; left: -100%; top: 0; bottom: 0; width: 100%; background: rgba(232,75,26,.05); transition: left .3s; }
    .contact-link:hover::before { left: 0; }
    .contact-link:hover { color: var(--accent); border-bottom-color: var(--accent); }
    .contact-link-platform { font-family: var(--font-display); font-weight: 600; font-size: .9rem; }
    .contact-link-handle { font-size: .7rem; letter-spacing: .05em; }
    .contact-link-arr { font-size: 1rem; }

    /* ─── FOOTER ─── */
    footer { padding: 2rem 3rem; border-top: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; font-size: .65rem; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); position: relative; z-index: 2; }

    /* ─── ANIMATIONS ─── */
    @keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: .2; } }
    @keyframes scrollPulse { 0% { transform: scaleY(1); opacity: 1; } 100% { transform: scaleY(.3); opacity: 0; } }

    /* ─── REVEAL ─── */
    .reveal { opacity: 0; transform: translateY(20px); transition: opacity 500ms var(--ease-out), transform 500ms var(--ease-out); }
    .reveal.visible { opacity: 1; transform: translateY(0); }

    /* ─── PROJECT MODAL ─── */
    .modal-backdrop {
      position: fixed; inset: 0; z-index: 1000;
      background: rgba(245,242,235,.88);
      backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
      display: flex; align-items: center; justify-content: center; padding: 2rem;
      opacity: 0; pointer-events: none;
      transition: opacity 300ms var(--ease-out);
    }
    .modal-backdrop.open { opacity: 1; pointer-events: all; }
    .modal-backdrop:not(.open) { transition: opacity 150ms ease-in; }
    .modal {
      background: #faf8f3; border: 1px solid var(--border);
      max-width: 780px; width: 100%; max-height: 88vh; overflow-y: auto;
      position: relative; transform: translateY(28px) scale(.98);
      transition: transform 350ms var(--ease-out), opacity 350ms var(--ease-out);
      scrollbar-width: thin; scrollbar-color: var(--muted) transparent;
      box-shadow: 0 24px 60px rgba(20,18,16,.1);
    }
    .modal-backdrop.open .modal { transform: translateY(0) scale(1); }
    .modal-backdrop:not(.open) .modal { transition: transform 180ms ease-in, opacity 180ms ease-in; }
    .modal-bar { height: 3px; width: 100%; }
    .modal-header { padding: 2rem 2.5rem 1.5rem; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; }
    .modal-num { font-size: .62rem; letter-spacing: .18em; color: var(--muted); margin-bottom: .6rem; }
    .modal-title { font-family: var(--font-display); font-weight: 800; font-size: 1.7rem; line-height: 1.1; }
    .modal-close { background: none; border: 1px solid var(--border); color: var(--dim); cursor: none; width: 36px; height: 36px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 1rem; line-height: 1; transition: border-color 150ms ease-out, color 150ms ease-out; margin-top: .2rem; }
    .modal-close:hover { border-color: var(--accent); color: var(--accent); }
    .modal-body { padding: 2rem 2.5rem; }
    .modal-section { margin-bottom: 2rem; }
    .modal-section:last-child { margin-bottom: 0; }
    .modal-label { font-size: .62rem; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: .8rem; display: flex; align-items: center; gap: .6rem; }
    .modal-label::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right, var(--border), transparent); }
    .modal-desc { font-size: .9rem; line-height: 1.85; color: var(--dim); }
    .modal-desc p { margin-bottom: .9rem; }
    .modal-desc p:last-child { margin-bottom: 0; }
    .modal-desc strong { color: var(--text); font-weight: 400; }
    .modal-tags { display: flex; flex-wrap: wrap; gap: .5rem; }
    .modal-tag { font-size: .65rem; letter-spacing: .1em; text-transform: uppercase; border: 1px solid var(--border); padding: .3rem .7rem; color: var(--dim); transition: border-color 150ms ease-out, color 150ms ease-out; }
    .modal-tag:hover { border-color: var(--accent); color: var(--accent); }
    .modal-links { display: flex; flex-wrap: wrap; gap: .8rem; }
    .modal-link-btn { font-family: var(--font-mono); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; padding: .65rem 1.3rem; display: inline-flex; align-items: center; gap: .5rem; transition: background 150ms ease-out, border-color 150ms ease-out, color 150ms ease-out; cursor: none; }
    .modal-link-btn.primary { background: var(--accent); color: #faf8f3; border: 1px solid var(--accent); }
    .modal-link-btn.primary:hover { background: var(--text); border-color: var(--text); }
    .modal-link-btn.secondary { background: none; color: var(--dim); border: 1px solid var(--border); }
    .modal-link-btn.secondary:hover { border-color: var(--accent); color: var(--accent); }

    /* ── Carousel ── */
    .modal-carousel { position: relative; background: var(--surface); border: 1px solid var(--border); overflow: hidden; user-select: none; }
    .carousel-track-wrap { overflow: hidden; position: relative; }
    .carousel-track { display: flex; transition: transform 280ms var(--ease-out); }
    .carousel-slide { flex: 0 0 100%; aspect-ratio: 16/9; position: relative; background: var(--surface); display: flex; align-items: center; justify-content: center; overflow: hidden; }
    .carousel-slide img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .carousel-slide.placeholder { background: var(--surface); }
    .carousel-slide.placeholder::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(rgba(232,75,26,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(232,75,26,.04) 1px, transparent 1px); background-size: 30px 30px; }
    .carousel-slide-label { position: relative; z-index: 1; font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
    .carousel-caption { padding: .7rem 1.2rem; border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; min-height: 44px; background: var(--surface); }
    .carousel-caption-text { font-size: .7rem; color: var(--dim); letter-spacing: .04em; }
    .carousel-counter { font-family: var(--font-mono); font-size: .62rem; color: var(--muted); white-space: nowrap; }
    .carousel-btn { position: absolute; top: 50%; z-index: 10; transform: translateY(-50%); background: rgba(245,242,235,.85); border: 1px solid var(--border); color: var(--dim); cursor: none; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; font-size: .85rem; line-height: 1; transition: border-color 150ms ease-out, color 150ms ease-out; backdrop-filter: blur(4px); }
    .carousel-btn:hover { border-color: var(--accent); color: var(--accent); }
    .carousel-btn.prev { left: .8rem; }
    .carousel-btn.next { right: .8rem; }
    .carousel-btn:disabled { opacity: .25; pointer-events: none; }
    .carousel-dots { display: flex; gap: .45rem; align-items: center; }
    .carousel-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--muted); border: none; padding: 0; cursor: none; transition: all .2s; }
    .carousel-dot.active { background: var(--accent); transform: scale(1.3); }
    .modal-stats { display: flex; gap: 2.5rem; flex-wrap: wrap; }
    .modal-stat-val { font-family: var(--font-display); font-weight: 800; font-size: 1.6rem; color: var(--text); line-height: 1; }
    .modal-stat-val span { color: var(--accent); }
    .modal-stat-lbl { font-size: .62rem; letter-spacing: .1em; text-transform: uppercase; color: var(--dim); margin-top: .25rem; }

    /* ─── INLINE PROSE LINK ─── */
    .prose-link {
      color: var(--accent);
      font-weight: 400;
      text-decoration: underline;
      text-decoration-color: transparent;
      text-underline-offset: 3px;
      transition: text-decoration-color .2s;
    }
    .prose-link:hover {
      text-decoration-color: var(--accent);
    }

    /* ─── REDUCED MOTION ─── */
    @media (prefers-reduced-motion: reduce) {
      .hero-tag, .hero-title, .hero-sub, .scroll-hint {
        animation: none;
        opacity: 1;
        transform: none;
      }
      .reveal {
        transition: none;
        opacity: 1;
        transform: none;
      }
      .modal, .modal-backdrop {
        transition: none;
      }
      .carousel-track {
        transition: none;
      }
    }

    /* ─── RESPONSIVE ─── */
    @media (max-width: 900px) {
      nav { padding: 1rem 1.5rem; }
      .nav-links { display: none; }
      #hero { padding: 0 1.5rem 4rem; }
      .hero-sub { flex-direction: column; gap: 2rem; }
      #about { grid-template-columns: 1fr; gap: 3rem; padding: 5rem 1.5rem; }
      #research, #projects, #hobbies, #cv, #contact { padding: 5rem 1.5rem; }
      .projects-grid { grid-template-columns: 1fr; background: none; gap: 1rem; }
      .proj-card.wide, .proj-card.narrow, .proj-card.full, .proj-card.third { grid-column: span 1; }
      .hobbies-grid { grid-template-columns: 1fr; }
      #cv { grid-template-columns: 1fr; gap: 3rem; }
      .contact-inner { grid-template-columns: 1fr; gap: 3rem; }
    }
    /* ─── STRAVA WORDMARK FIX ─── */
    .strava-header { overflow: visible !important; }
    .strava-profile-link { overflow: visible !important; flex-shrink: 0 !important; }
    .strava-profile-link svg { overflow: visible !important; display: block; }
    #running { overflow: visible !important; }