:root{--bg: #050711;--panel: #0c1020;--text: #f6f9ff;--muted: #a8b3c7;--accent: #7cf5ff;--accent-2: #ff8bd1;--border: rgba(255, 255, 255, .12);--card: #0f1528;--shadow: 0 24px 80px rgba(0, 0, 0, .45);font-family:Plus Jakarta Sans,system-ui,-apple-system,sans-serif;color:var(--text)}body.theme-dark{--bg: #050711;--panel: #0c1020;--text: #f6f9ff;--muted: #a8b3c7;--accent: #7cf5ff;--accent-2: #ff8bd1;--border: rgba(255, 255, 255, .12);--card: #0f1528;--shadow: 0 24px 80px rgba(0, 0, 0, .45);background:radial-gradient(circle at 12% 18%,rgba(255,139,209,.32),transparent 28%),radial-gradient(circle at 84% 12%,rgba(124,245,255,.28),transparent 30%),radial-gradient(circle at 30% 80%,rgba(124,245,255,.18),transparent 30%),radial-gradient(circle at 82% 78%,rgba(255,214,102,.12),transparent 32%),linear-gradient(160deg,#06081a,#0b0f25,#050711);color:var(--text)}body.theme-light{--bg: #fafafc;--panel: #ffffff;--card: #ffffff;--text: #0f172a;--muted: #475569;--accent: #2563eb;--accent-2: #7c3aed;--border: rgba(15, 23, 42, .12);--shadow: 0 24px 64px rgba(15, 23, 42, .08);background:radial-gradient(circle at 12% 18%,rgba(37,99,235,.08),transparent 32%),radial-gradient(circle at 82% 18%,rgba(124,58,237,.06),transparent 34%),linear-gradient(180deg,#fff,#fafafc);color:var(--text)}body.theme-light .nav a{color:var(--text)}body.theme-light .nav a:hover{background:#00000014}body.theme-light .hero{background:linear-gradient(145deg,#2563eb14,#7c3aed14),var(--panel)}body.theme-light .logo{background:linear-gradient(135deg,#d1d5db,#cbd5e1,#9ca3af);color:#0f172a;box-shadow:0 6px 16px #16a34a14}body.theme-light .btn{background:linear-gradient(135deg,#e5e7eb,#cbd5e1);color:#0f172a;font-weight:700;border:1px solid var(--border);box-shadow:0 8px 20px #0f172a14}body.theme-light .btn.btn--cv{background:linear-gradient(135deg,#d1d5db,#cbd5e1,#9ca3af);color:#0f172a;border:1px solid rgba(22,163,74,.16);box-shadow:0 12px 28px #0f172a1f}body.theme-light .btn.ghost{background:#ffffff80;color:#0f172a;border:1px solid rgba(15,23,42,.16);box-shadow:0 4px 12px #0f172a0f}body.theme-light .tags span{background:#0000000f;color:var(--text);border-color:#374b4a38}body.theme-light .hero .lede{color:#273a37}body.theme-light .experience-bullets,body.theme-light .timeline-card-date{color:var(--text)}body.theme-light .drawer__label{color:#273a37}*{box-sizing:border-box}body{margin:0;min-height:100vh;color:var(--text)}a{color:inherit;text-decoration:none}.page{max-width:1200px;margin:0 auto;padding:32px 24px 80px}.nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;margin-bottom:18px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0c0d1199;border:1px solid var(--border);border-radius:14px}.nav nav{display:flex;gap:14px;flex-wrap:wrap}.nav a{padding:8px 12px;border-radius:10px;color:var(--muted);transition:all .2s ease}.nav a:hover{color:var(--text);background:#ffffff0a}.logo{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));font-weight:700;color:#0d0f14}.hero{position:relative;padding:80px 24px;border:1px solid var(--border);border-radius:20px;background:linear-gradient(145deg,#8b8bae2e,#5267602e),var(--panel);box-shadow:var(--shadow);overflow:hidden}.hero__content{max-width:720px}.hero h1{font-size:clamp(36px,6vw,56px);margin:10px 0 16px;letter-spacing:-.03em}.hero .lede{color:var(--muted);max-width:560px}.hero__meta{display:flex;flex-direction:column;gap:12px;margin:0}.hero__meta .meta-chip{padding:0;border:none;background:none;color:var(--accent);font-size:14px}.meta-chip{padding:8px 12px;border-radius:10px;border:1px solid var(--border);background:#ffffff0d;color:var(--text);font-size:14px}.meta-chip.link{color:var(--accent);border-color:#6ee7ff4d}.hero__cta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}.hero__badge{position:absolute;right:24px;bottom:24px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#ffffff0f;color:var(--text);display:inline-flex;gap:8px;align-items:center;box-shadow:0 10px 30px #00000059}.hero .eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:12px}.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#0d0f14;font-weight:600;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;box-shadow:0 14px 36px #ff8bd140}.btn:hover{transform:translateY(-1px);box-shadow:0 15px 35px #7c3aed40}.btn.ghost{background:#f6f0ed1a;color:var(--text);border:1px solid var(--border);box-shadow:none}.section{margin-top:64px;padding:32px;border-radius:18px;border:1px solid var(--border);background:var(--panel)}.section__title{font-weight:700;margin-bottom:12px;letter-spacing:.01em}.section__body{color:var(--muted);line-height:1.6}.skills-section{margin-top:24px;display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.skill-category h4{font-size:12px;font-weight:700;color:var(--text);margin:0 0 12px;text-transform:uppercase;letter-spacing:.08em}.skill-category .pillrow{margin-top:0;gap:8px}.pillrow{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.pill{display:inline-flex;padding:8px 12px;border-radius:999px;background:#ffffff0d;color:var(--text);border:1px solid var(--border);font-size:14px}.pill.link{color:var(--accent);border-color:#6ee7ff4d}.theme-toggle__emoji{position:absolute;top:50%;transform:translateY(-50%);font-size:12px;opacity:0;transition:opacity .2s ease;pointer-events:none}.theme-toggle__emoji-light{right:8px}.theme-toggle__emoji-dark{left:8px}.theme-toggle--light .theme-toggle__emoji-light,.theme-toggle--dark .theme-toggle__emoji-dark{opacity:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.theme-toggle{width:54px;height:30px;padding:0;border:1px solid var(--border);background:#ffffff14;border-radius:999px;position:relative;cursor:pointer;display:inline-flex;align-items:center;justify-content:flex-start;transition:background .2s ease,border-color .2s ease}.theme-toggle:after{content:"";position:absolute;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px #00000040;transform:translate(4px);transition:transform .25s ease}.theme-toggle--light{background:#eef2ff;border-color:var(--border)}.theme-toggle--light:after{transform:translate(28px)}.theme-toggle--dark{background:#ffffff14;border-color:var(--border)}.theme-toggle--dark:after{transform:translate(4px)}body.theme-light .nav{background:#ffffffbf;border-color:var(--border)}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.projects{display:grid;grid-template-columns:2fr 1fr;gap:18px;align-items:start}.projects__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;max-height:calc(100vh - 50px);overflow:auto;padding:6px 8px 6px 2px;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(37,99,235,.35) transparent}.projects__grid .card{min-height:160px;display:flex;flex-direction:column}.projects__grid .card p{margin-top:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.projects__grid::-webkit-scrollbar{width:36px}.projects__grid::-webkit-scrollbar-track{background:transparent}.projects__grid::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#2563eb8c,#7c3aed73);border-radius:999px;min-height:60px;margin:8px 6px}.projects__grid::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#2563ebbf,#7c3aeda6)}.card{padding:18px;border-radius:14px;border:1px solid var(--border);background:var(--card);cursor:pointer;transition:all .2s ease}.card .card-github-link,.card .card-description,.card .card-image{display:none}.card:hover{border-color:#6ee7ff99;transform:translateY(-2px)}.card--active{border-color:#7c3aedb3;box-shadow:var(--shadow)}.timeline-card-date{font-size:12px;color:var(--muted);font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.card__header{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.experience-bullets{list-style:disc;padding-left:20px;margin:8px 0 0;color:var(--muted)}.experience-bullets li{margin-bottom:4px;font-size:14px;line-height:1.5}.tags{display:flex;gap:6px;flex-wrap:wrap}.tags span{padding:4px 8px;border-radius:10px;background:#ffffff0a;color:var(--muted);border:1px solid var(--border);font-size:12px}.projects__drawer{padding:18px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(145deg,#7cf5ff24,#ff8bd124);color:var(--text);position:sticky;top:90px;max-height:calc(100vh - 50px);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none;box-shadow:var(--shadow)}.projects__drawer::-webkit-scrollbar{display:none}.project-image{width:100%;height:480px;object-fit:contain;border-radius:10px;margin-bottom:14px;border:1px solid var(--border)}.projects__drawer p{white-space:pre-line;line-height:1.8}.projects__drawer .link{display:inline-block;margin-top:-20px}.drawer__label{text-transform:uppercase;font-size:12px;color:var(--muted);letter-spacing:.08em;margin-bottom:6px}.list{padding-left:18px;color:var(--muted);display:grid;gap:10px}.timeline{margin-top:16px;position:relative}.timeline-unified{position:relative;margin-top:40px;padding:0 20px}.timeline-present-marker{text-align:center;color:var(--accent);font-weight:700;font-size:18px;margin-bottom:30px;text-transform:uppercase;letter-spacing:.1em}.timeline-present-marker #about.section{padding:24px}.timeline-present-marker #about .section__title{margin-bottom:8px;font-size:18px}.timeline-present-marker #about .section__body{font-size:15px}.timeline-present-marker #about .skills-section{gap:8px;margin-top:8px}.timeline-present-marker #about .skill-category{margin-bottom:2px}.timeline-present-marker #about .skill-category h4{font-size:8px;margin-bottom:4px}.timeline-present-marker #about .pillrow{gap:4px;margin-top:2px}.timeline-present-marker #about .pill{font-size:10px;padding:4px 6px}.timeline-item{display:grid;grid-template-columns:1fr minmax(auto,60px) auto minmax(0,120px) auto minmax(auto,60px) 1fr;gap:0;margin-bottom:44px;position:relative;align-items:center}.timeline-item-left .timeline-item-content{grid-column:1;display:flex;justify-content:flex-end;padding-right:-2px}.timeline-item-left .timeline-date-badge{grid-column:2;justify-self:end;padding-right:8px;margin-right:-40px}.timeline-item-left .timeline-center{grid-column:4}.timeline-item-left .timeline-item-spacer{grid-column:7}.timeline-item-right .timeline-item-spacer{grid-column:1}.timeline-item-right .timeline-center{grid-column:4}.timeline-item-right .timeline-date-badge{grid-column:6;justify-self:start;padding-left:8px;margin-left:-40px}.timeline-item-right .timeline-item-content{grid-column:7;display:flex;justify-content:flex-start;padding-left:-2px}.timeline-connector{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:120px;z-index:3}.timeline-connector-left{right:0}.timeline-connector-right{left:0}.timeline-connector-line{width:100%;height:2px;background:var(--border);display:none}.timeline-connector-date{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--panel);color:var(--muted);font-weight:600;font-size:12px;padding:3px 8px;border-radius:8px;border:1px solid var(--border);white-space:nowrap;z-index:4;display:none}.timeline-connector{position:absolute;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:120px;pointer-events:none;z-index:3}.timeline-connector-left{right:-120px}.timeline-connector-right{left:-120px}.timeline-center{grid-column:2;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;z-index:2}.timeline-date-side{font-size:12px;color:var(--muted);font-weight:600;background:var(--panel);padding:3px 8px;border-radius:8px;border:1px solid var(--border);white-space:nowrap}.timeline-item-left .timeline-date-side{margin-left:0;margin-right:12px}.timeline-item-right .timeline-date-side{margin-left:12px;margin-right:0}.timeline-date-badge{display:flex;align-items:center;justify-content:center;text-align:center;font-size:12px;color:var(--muted);font-weight:600;background:var(--panel);padding:3px 8px;border-radius:8px;border:1px solid var(--border);white-space:nowrap;grid-column:auto}.timeline-center-node{width:16px;height:16px;border-radius:50%;background:var(--accent-2);border:3px solid var(--panel);box-shadow:0 0 0 2px var(--border);z-index:3}.timeline-unified:before{content:"";position:absolute;top:36px;bottom:0;left:50%;transform:translate(-50%);width:3px;background:linear-gradient(180deg,var(--accent),var(--accent-2));z-index:1}.timeline-container{display:grid;grid-template-columns:1fr 60px 1fr;gap:24px;margin-top:24px;align-items:start}.timeline-item-wrapper{display:flex;align-items:center;position:relative}.timeline-left .timeline-item-wrapper{justify-content:flex-end}.timeline-right .timeline-item-wrapper{justify-content:flex-start}.timeline-column{display:flex;flex-direction:column;gap:32px;position:relative}.timeline-column:before{content:"";position:absolute;top:80px;bottom:0;width:2px;background:var(--border)}.timeline-left:before{right:-32px}.timeline-right:before{left:-32px}.timeline-heading{text-align:center;color:var(--accent);margin:0 0 12px;font-size:18px;letter-spacing:.05em;text-transform:uppercase}.timeline__card{padding:18px;border-radius:14px;border:1px solid var(--border);background:var(--card);transition:all .3s ease;max-width:400px;cursor:pointer;overflow:hidden;position:relative}.timeline-date-side{position:absolute;top:18px;font-size:12px;color:var(--muted);font-weight:600;background:#ffffff0d;padding:4px 8px;border-radius:6px;border:1px solid var(--border)}.timeline-item-left .timeline-date-side{left:18px}.timeline-item-right .timeline-date-side{right:18px}.timeline__card h4{margin:0;color:var(--text);transition:color .3s ease}.timeline__expandable{max-height:0;opacity:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease,margin-top .3s ease}.timeline__card:hover .timeline__expandable{max-height:300px;opacity:1;margin-top:12px}.timeline-middle{display:flex;justify-content:center;position:relative}.timeline-dates{position:absolute;display:flex;flex-direction:column;gap:80px;top:80px;z-index:1}.timeline-year{background:var(--panel);color:var(--accent);padding:8px 14px;border-radius:12px;border:2px solid var(--accent-2);font-weight:700;font-size:16px;text-align:center;box-shadow:0 4px 12px #0000004d}.timeline-line-vertical{width:3px;background:linear-gradient(180deg,var(--accent),var(--accent-2));border-radius:4px;height:100%;position:absolute;top:0;bottom:0}.timeline__card:hover{border-color:#7cf5ff80;transform:translateY(-2px);box-shadow:0 12px 30px #0000004d}.timeline__card h4{margin:6px 0 4px;color:var(--text)}.timeline__card p{margin:4px 0}@media (max-width: 900px){.timeline-container{grid-template-columns:1fr;gap:16px}.timeline-middle,.timeline-connector{display:none}.timeline-column:before{display:none}.timeline-item-wrapper{justify-content:flex-start!important}.timeline__card{max-width:100%}}.timeline__item{display:grid;grid-template-columns:30px 1fr;gap:12px;position:relative}.timeline__node{width:14px;height:14px;border-radius:50%;background:var(--accent-2);margin-top:4px}.timeline__line{position:absolute;left:6px;top:18px;bottom:-12px;width:2px;background:var(--border)}.timeline__content h4{margin:4px 0}.timeline__meta{color:var(--muted);font-size:13px;letter-spacing:.01em}.muted{color:var(--muted)}.contact .pill{background:#6ee7ff1a;color:var(--text)}.link{color:var(--accent);text-decoration:none}.footer{margin-top:60px;padding-top:18px;border-top:1px solid var(--border);color:var(--muted);display:flex;gap:12px;justify-content:space-between;flex-wrap:wrap}.scroll-to-top{position:fixed;bottom:32px;right:32px;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #00000040;transition:all .3s ease;z-index:100;color:#0d0f14}.scroll-to-top:hover{transform:translateY(-3px);box-shadow:0 12px 28px #00000059}body.theme-light .scroll-to-top{background:linear-gradient(135deg,#d1d5db,#cbd5e1,#9ca3af);color:#0f172a;box-shadow:0 8px 20px #0f172a26}@media (max-width: 900px){.projects{grid-template-columns:1fr}.projects__drawer{position:static;max-height:none;overflow-y:visible;margin-bottom:20px}.project-image{height:300px}.nav{position:sticky;top:0}.timeline-item{grid-template-columns:auto 1fr;gap:0}.timeline-item-left .timeline-item-content,.timeline-item-right .timeline-item-content{grid-column:2;justify-content:flex-start;padding-left:20px;padding-right:0}.timeline-item-spacer{display:none}.timeline-center{grid-column:1}.timeline__card{max-width:100%}}@media (max-width: 640px){.page{padding:20px 18px 60px}.hero{padding:60px 18px}.section{padding:22px}.nav{padding:8px 12px;margin-bottom:12px}.nav nav{gap:6px}.nav a{padding:6px 8px;font-size:13px}.logo{width:28px;height:28px;font-size:13px}.projects__drawer{display:none!important}.projects__grid{display:flex;flex-direction:column;gap:20px}.card{cursor:default;padding:24px!important;display:flex;flex-direction:column;min-height:360px!important;justify-content:space-between}.card__header{flex-direction:column;align-items:flex-start;margin-bottom:12px}.card__header h3{font-size:18px;margin:0 0 10px;font-weight:700}.card .card-image{display:none!important}.card .card-github-link{display:block!important;color:var(--accent);font-size:13px;margin:10px 0 0;text-decoration:none;font-weight:600}.card .card-description{display:none!important}.card .card-blurb{display:block!important;font-size:13px;line-height:1.6;margin:0 0 12px;color:var(--muted)}.tags{gap:8px;margin:0}.tags span{font-size:11px;padding:5px 9px}.timeline-unified{display:flex;flex-direction:column;gap:16px;position:relative}.timeline-unified:before{display:none}.timeline-present-marker{position:static;margin-bottom:12px}.timeline-item{display:block!important;grid-template-columns:none!important}.timeline-item-content{padding:0!important;display:block!important}.timeline-item-spacer,.timeline-center,.timeline-date-badge{display:none!important}.timeline__card{max-width:100%;padding:14px}.timeline__card h4{font-size:15px;margin-bottom:6px}.timeline__card .timeline__expandable{max-height:none!important;opacity:1!important;margin-top:8px!important}.timeline-card-date{font-size:12px;font-weight:600;color:var(--accent);margin-bottom:4px}.experience-bullets{font-size:12px;gap:6px;margin-top:8px}}
