@import url(https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Instrument+Serif:ital@0;1&display=swap);@import url(https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Archivo+Black&family=IBM+Plex+Mono:wght@400;500;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600&family=Manrope:wght@400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap);@import url(https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Manrope:wght@400;500;600;700&display=swap);@import url(https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700&family=EB+Garamond:wght@400;500;600;700&family=Source+Sans+3:wght@400;500;600;700&display=swap);.terminal-container{background:#fffcf6e0;border:1px solid var(--border-color);border-radius:28px;box-shadow:var(--shadow-soft);font-family:IBM Plex Mono,monospace;margin:4rem auto;overflow:hidden;width:min(92%,940px)}.terminal-header{align-items:center;background:#ffffff70;border-bottom:1px solid var(--border-color);display:flex;padding:.95rem 1rem;position:relative}.terminal-header-dot{border-radius:50%;height:11px;margin-right:8px;width:11px}.terminal-header-dot.red{background:#d95b43}.terminal-header-dot.yellow{background:#d3a63c}.terminal-header-dot.green{background:#2457d6}.terminal-header span{color:var(--secondary-text-color);font-size:.85rem;left:50%;letter-spacing:.14em;position:absolute;text-transform:uppercase;transform:translateX(-50%)}.terminal-body{color:var(--primary-text-color);cursor:text;height:400px;overflow-y:auto;padding:1.5rem}.terminal-line{word-wrap:break-word;line-height:1.7;margin:0 0 .6rem;white-space:pre-wrap}.terminal-line.user{color:var(--primary-text-color)}.terminal-line.system{color:var(--secondary-text-color)}.terminal-line.success{color:var(--accent-cyan)}.terminal-line.error{color:var(--accent-magenta)}.terminal-line.link a{color:var(--accent-cyan);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.terminal-line.link a:hover{color:var(--accent-magenta)}.terminal-prompt{align-items:center;display:flex}.prompt-text{color:var(--accent-cyan);margin-right:8px}.terminal-prompt form{flex-grow:1}.terminal-input{background:#0000;border:none;caret-color:var(--accent-magenta);color:var(--primary-text-color);font-family:IBM Plex Mono,monospace;margin:0;outline:none;padding:0;width:100%}:root{--bg-color:#f6efe2;--paper-color:#fffbf3d1;--paper-strong:#fffcf6f0;--primary-text-color:#1c2738;--secondary-text-color:#5d6472;--accent-cyan:#2457d6;--accent-magenta:#d95b43;--accent-gold:#d3a63c;--border-color:#1c27381f;--card-bg:#fffcf6bd;--accent-cyan-glow:#2457d62e;--shadow-soft:0 18px 48px #1c273814;--logo-badge-bg:#343942;--logo-badge-border:#1c273829;--nav-shell-bg:#fffcf6c7;--nav-wash:linear-gradient(180deg,#f6efe2f5,#f6efe2c2 70%,#0000);--hero-shell-bg:linear-gradient(145deg,#fffbf3d6,#ffffff94);--button-inverse-text:#fff7ee;--ghost-pill-bg:#ffffff7a;--ghost-button-bg:#ffffff80;--surface-strong-bg:#ffffffb8;--surface-soft-bg:#ffffff8f;--inner-highlight:#fff6}html[data-theme=cosmic]{--bg-color:#0f1018;--paper-color:#12131dd6;--paper-strong:#141622f0;--primary-text-color:#e9edf4;--secondary-text-color:#9aa1b1;--accent-gold:#ffd166;--accent-cyan-glow:#00fff938;--shadow-soft:0 18px 52px #0006;--logo-badge-bg:#343942;--logo-badge-border:#00fff933;--nav-shell-bg:#0e0f17d1;--nav-wash:linear-gradient(180deg,#0c0d14f5,#0c0d14bd 70%,#0000);--hero-shell-bg:linear-gradient(145deg,#10121beb,#1a1c28c2);--button-inverse-text:#081213;--ghost-pill-bg:#ffffff0d;--ghost-button-bg:#ffffff0f;--surface-strong-bg:#ffffff0f;--surface-soft-bg:#ffffff0a;--inner-highlight:#ffffff0d}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:radial-gradient(circle at top left,#2457d61f,#0000 24%),radial-gradient(circle at 85% 18%,#d95b4324,#0000 22%),radial-gradient(circle at 20% 80%,#d3a63c1f,#0000 18%),linear-gradient(180deg,#ffffff61,#0000 45%),repeating-linear-gradient(0deg,#1c27380a,#1c27380a 1px,#0000 0,#0000 38px),repeating-linear-gradient(90deg,#1c273808,#1c273808 1px,#0000 0,#0000 38px),#f6efe2;background:radial-gradient(circle at top left,#2457d61f,#0000 24%),radial-gradient(circle at 85% 18%,#d95b4324,#0000 22%),radial-gradient(circle at 20% 80%,#d3a63c1f,#0000 18%),linear-gradient(180deg,#ffffff61,#0000 45%),repeating-linear-gradient(0deg,#1c27380a 0,#1c27380a 1px,#0000 1px,#0000 38px),repeating-linear-gradient(90deg,#1c273808 0,#1c273808 1px,#0000 1px,#0000 38px),var(--bg-color);color:#1c2738;color:var(--primary-text-color);font-family:IBM Plex Mono,monospace;overflow-x:hidden}html[data-theme=cosmic] body{background:radial-gradient(circle at top left,#00fff929,#0000 20%),radial-gradient(circle at 82% 16%,#ff00c12e,#0000 18%),radial-gradient(circle at 18% 82%,#ffd1661a,#0000 18%),linear-gradient(180deg,hsla(0,0%,100%,.015),#0000 45%),repeating-linear-gradient(0deg,hsla(0,0%,100%,.045),hsla(0,0%,100%,.045) 1px,#0000 0,#0000 38px),repeating-linear-gradient(90deg,#ffffff08,#ffffff08 1px,#0000 0,#0000 38px),#f6efe2;background:radial-gradient(circle at top left,#00fff929,#0000 20%),radial-gradient(circle at 82% 16%,#ff00c12e,#0000 18%),radial-gradient(circle at 18% 82%,#ffd1661a,#0000 18%),linear-gradient(180deg,hsla(0,0%,100%,.015),#0000 45%),repeating-linear-gradient(0deg,hsla(0,0%,100%,.045) 0,hsla(0,0%,100%,.045) 1px,#0000 1px,#0000 38px),repeating-linear-gradient(90deg,#ffffff08 0,#ffffff08 1px,#0000 1px,#0000 38px),var(--bg-color)}a,button,input,textarea{font:inherit}img{display:block}.navbar{background:linear-gradient(180deg,#f6efe2f5,#f6efe2c2 70%,#0000);background:var(--nav-wash);padding:1.2rem 0 0;position:-webkit-sticky;position:sticky;top:0;z-index:999}.navbar-inner{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#fffcf6c7;background:var(--nav-shell-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:999px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);gap:1.5rem;justify-content:space-between;margin:0 auto;padding:1rem 1.4rem;width:min(92%,1240px)}.logo-title,.navbar-inner{align-items:center;display:flex}.logo-title{gap:.95rem;min-width:0}.nav-logo{background:#343942;background:var(--logo-badge-bg);border:1px solid #1c273829;border:1px solid var(--logo-badge-border);border-radius:18px;box-shadow:inset 0 1px 0 #ffffff0f;height:58px;object-fit:cover;padding:.3rem;width:58px}.nav-name{color:#1c2738;color:var(--primary-text-color);font-family:"Instrument Serif",serif;font-size:1.8rem;letter-spacing:.02em}.nav-links{align-items:center;display:flex;flex-wrap:wrap;gap:1.1rem}.nav-links a{color:#5d6472;color:var(--secondary-text-color);font-size:.95rem;letter-spacing:.12em;text-decoration:none;text-transform:uppercase;transition:color .2s ease,transform .2s ease}.nav-links a:hover{color:#2457d6;color:var(--accent-cyan);transform:translateY(-1px)}.hero{align-items:center;display:flex;justify-content:center;min-height:90vh;padding:4rem 0 2rem;position:relative;text-align:center;width:100%}.hero:after,.hero:before{border-radius:999px;content:"";pointer-events:none;position:absolute}.hero:before{background:radial-gradient(circle,#2457d629,#0000 70%);filter:blur(10px);height:26rem;left:6%;top:8%;width:26rem}.hero:after{background:radial-gradient(circle,#d95b4333,#0000 72%);bottom:12%;filter:blur(8px);height:18rem;right:9%;width:18rem}.hero-content{background:linear-gradient(145deg,#fffbf3d6,#ffffff94);background:var(--hero-shell-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:36px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);padding:3.5rem 3rem;position:relative;width:min(92%,980px);z-index:1}.hero-content:before{color:#2457d6;color:var(--accent-cyan);content:"Portfolio / 2026 Edition";display:inline-block;font-size:.82rem;letter-spacing:.2em;margin-bottom:1.4rem;text-transform:uppercase}.hero-content h1{font-family:"Instrument Serif",serif;font-size:clamp(4rem,9vw,7rem);font-weight:400;line-height:.92;margin-bottom:1.5rem}.hero-content p{color:#5d6472;color:var(--secondary-text-color);font-size:1.02rem;line-height:1.95;margin:0 auto;max-width:720px}.contact-container,.featured-project-section,.skills-container,.timeline-container{width:min(92%,1240px)}.featured-project-section{margin:0 auto 5rem}.featured-project-shell{background:radial-gradient(circle at top left,#2457d61f,#0000 28%),radial-gradient(circle at bottom right,#d95b431c,#0000 24%),#fffbf3d1;background:radial-gradient(circle at top left,#2457d61f,#0000 28%),radial-gradient(circle at bottom right,#d95b431c,#0000 24%),var(--paper-color);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:32px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);padding:2.8rem}.featured-project-header{margin-bottom:1.3rem;max-width:none}.featured-project-kicker,.project-media-kicker,.system-detail-kicker{color:#2457d6;color:var(--accent-cyan);display:inline-block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase}.featured-project-header h2{font-family:"Instrument Serif",serif;font-size:clamp(2.9rem,6vw,4.8rem);line-height:.95;margin:.7rem 0 1rem}.about-text p,.contact-item,.featured-project-header p,.featured-project-summary p,.project-details p,.project-media-placeholder p,.system-detail-stack,.system-detail-summary,.timeline-project-preview{color:#5d6472;color:var(--secondary-text-color)}.featured-project-header p,.featured-project-summary p{line-height:1.9;max-width:none}.featured-project-summary,.system-selector{margin-bottom:1.4rem}.system-selector{display:flex;flex-wrap:wrap;gap:.8rem}.system-selector-button{background:#ffffff7a;background:var(--ghost-pill-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:999px;color:#5d6472;color:var(--secondary-text-color);cursor:pointer;padding:.78rem 1.1rem;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .2s ease}.system-selector-button.active,.system-selector-button:hover{background:#1c2738;background:var(--primary-text-color);border-color:#1c2738;border-color:var(--primary-text-color);color:#fff7ee;color:var(--button-inverse-text);transform:translateY(-1px)}.system-detail-card{background:#fffcf6f0;background:var(--paper-strong);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:24px;box-shadow:inset 0 1px 0 #fff6;box-shadow:inset 0 1px 0 var(--inner-highlight);padding:1.8rem}.system-detail-topbar{margin-bottom:1rem}.system-detail-topbar h3{font-family:"Instrument Serif",serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;line-height:.98}.system-detail-summary{line-height:1.85;margin-bottom:1rem}.system-detail-stack{line-height:1.8;margin-bottom:1.1rem}.system-detail-stack strong{color:#1c2738;color:var(--primary-text-color)}.system-log{grid-gap:.75rem;display:grid;gap:.75rem}.system-log-line{align-items:flex-start;display:flex;gap:.65rem;line-height:1.75}.system-log-prompt{color:#d95b43;color:var(--accent-magenta);font-weight:700;line-height:1.75}.featured-project-actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-top:1.6rem}.featured-project-button,.project-live-link,.timeline-read-more{align-items:center;border-radius:999px;display:inline-flex;justify-content:center;text-decoration:none;transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease}.featured-project-button{font-weight:600;padding:.9rem 1.25rem}.featured-project-button:hover,.project-live-link:hover{transform:translateY(-2px)}.featured-project-button.primary,.project-live-link{background:#1c2738;background:var(--primary-text-color);border:1px solid #1c2738;border:1px solid var(--primary-text-color);color:#fff7ee;color:var(--button-inverse-text)}.featured-project-button.secondary{background:#ffffff80;background:var(--ghost-button-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);color:#1c2738;color:var(--primary-text-color)}.featured-project-button.secondary:hover{border-color:#d95b43;border-color:var(--accent-magenta);color:#d95b43;color:var(--accent-magenta)}.timeline-container{margin:4rem auto;position:relative}.about-text h2,.skills-title,.timeline-title{font-family:"Instrument Serif",serif;font-size:clamp(2.8rem,5vw,4.2rem);font-weight:400;letter-spacing:.01em;margin-bottom:2.5rem;text-align:center}.timeline{padding:.5rem 0 0;position:relative}.timeline-line{background:linear-gradient(180deg,#0000,#2457d647,#d95b433d,#0000);bottom:0;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}.timeline-item{cursor:pointer;margin-bottom:2rem;padding:1rem 1.75rem;position:relative;width:50%}.timeline-item:nth-child(odd){left:0;padding-right:3.6rem;text-align:right}.timeline-item:nth-child(2n){left:50%;padding-left:3.6rem;text-align:left}.timeline-dot{background:#fffcf6f0;background:var(--paper-strong);border:4px solid #2457d6;border:4px solid var(--accent-cyan);border-radius:50%;height:18px;position:absolute;top:1.3rem;transition:transform .2s ease,background .2s ease;width:18px;z-index:1}.timeline-item:hover .timeline-dot{background:#d3a63c;background:var(--accent-gold);transform:scale(1.08)}.timeline-item:nth-child(odd) .timeline-dot{right:-9px}.timeline-item:nth-child(2n) .timeline-dot{left:-9px}.timeline-content{background:#fffcf6bd;background:var(--card-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:24px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);overflow:hidden;padding:1.6rem;position:relative;transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease}.timeline-content:before{background:linear-gradient(135deg,#2457d614,#0000 40%,#d95b430f);content:"";inset:0;opacity:0;position:absolute;transition:opacity .25s ease}.timeline-item:hover .timeline-content{border-color:#2457d652;box-shadow:0 22px 52px #1c27381f;transform:translateY(-4px) rotate(-.2deg)}.timeline-item:hover .timeline-content:before{opacity:1}.timeline-date{color:#d95b43;color:var(--accent-magenta);display:inline-block;font-size:.82rem;letter-spacing:.12em;margin-bottom:.7rem;position:relative;text-transform:uppercase;z-index:1}.timeline-project-title{font-family:"Instrument Serif",serif;font-size:2rem;font-weight:400;line-height:.98;margin-bottom:.75rem;position:relative;z-index:1}.timeline-project-preview{font-size:.92rem;line-height:1.8;position:relative;z-index:1}.timeline-read-more{color:#2457d6;color:var(--accent-cyan);font-weight:600;margin-top:.8rem}.about-container{padding:4rem 0}.about-content{grid-gap:2.4rem;align-items:center;display:grid;gap:2.4rem;grid-template-columns:minmax(0,1.55fr) minmax(260px,.85fr);margin:0 auto;width:min(92%,1150px)}.about-text{background:#fffbf3d1;background:var(--paper-color);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:30px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);padding:2.2rem}.about-text h2{margin-bottom:1.4rem;text-align:left}.about-text p{line-height:1.9;margin-bottom:1rem}.about-image{justify-self:center;max-width:340px;position:relative}.about-image img{background:#ffffffb8;background:var(--surface-strong-bg);border:1px solid #2457d624;border-radius:32px;box-shadow:0 22px 56px #1c27381a;padding:.7rem;transition:transform .25s ease;width:100%}.about-image:hover img{transform:translateY(-4px) rotate(-1deg)}html[data-theme=editorial] .about-image:after,html[data-theme=editorial] .about-image:before,html[data-theme=editorial] .main-image-container:after,html[data-theme=editorial] .main-image-container:before{content:"";height:72px;pointer-events:none;position:absolute;width:72px;z-index:2}html[data-theme=editorial] .about-image:before,html[data-theme=editorial] .main-image-container:before{border-left:6px solid #2457d661;border-top:6px solid #2457d661;border-top-left-radius:28px;left:-10px;top:-10px}html[data-theme=editorial] .about-image:after,html[data-theme=editorial] .main-image-container:after{border-bottom:6px solid #d95b4357;border-bottom-right-radius:28px;border-right:6px solid #d95b4357;bottom:-10px;right:-10px}.skills-container{margin:4rem auto}.skills-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.skill-category{background:#fffcf6bd;background:var(--card-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:28px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);padding:1.75rem;position:relative;text-align:left}.skill-category .border-svg{display:none}.skill-category h3{color:#1c2738;color:var(--primary-text-color);font-family:"Instrument Serif",serif;font-size:2rem;font-weight:400;margin-bottom:1rem}.skill-category ul{display:flex;flex-wrap:wrap;gap:.65rem;list-style:none}.skill-category li{background:#ffffff8f;background:var(--surface-soft-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:999px;color:#5d6472;color:var(--secondary-text-color);font-size:.9rem;padding:.5rem .8rem}.contact-container{margin:3rem auto}.contact-tile{background:#fffcf6bd;background:var(--card-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:24px;padding:2rem}.contact-tile h2{font-family:"Instrument Serif",serif;font-size:2.2rem;font-weight:400;margin-bottom:1rem}.contact-item a{color:#2457d6;color:var(--accent-cyan);text-decoration:none}.project-page-container{margin:0 auto;min-height:100vh;padding:2.2rem 0 4rem;width:min(92%,1120px)}.project-header{align-items:center;border-bottom:1px solid #1c27381f;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;margin-bottom:2rem;padding:1.2rem 0 2rem;text-align:center}.project-header h1{font-family:"Instrument Serif",serif;font-size:clamp(3rem,7vw,5.4rem);font-weight:400;line-height:.95;margin-bottom:.6rem}.project-header span{color:#d95b43;color:var(--accent-magenta);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}.project-body{display:flex;flex-direction:column;gap:2rem}.project-body.side-by-side{align-items:flex-start;flex-direction:row;gap:1.8rem}.project-body.side-by-side .project-gallery{flex:1 1;max-width:48%}.project-body.side-by-side .project-details{flex:1.1 1}.back-link{color:#2457d6;color:var(--accent-cyan);margin-bottom:1rem;text-decoration:none}.project-gallery{margin-bottom:2rem}.main-image-container{margin:0 auto 1rem;max-width:760px;position:relative;width:100%}.main-image,.main-video{background:#ffffff8f;background:var(--surface-soft-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:34px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);display:block;width:100%}.main-image{height:auto}.main-video{aspect-ratio:16/9}.thumbnail-container{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}.thumbnail-image{background:#ffffff8f;background:var(--surface-soft-bg);border:1px solid #2457d629;border-radius:20px;cursor:pointer;height:75px;object-fit:cover;padding:.2rem;transition:transform .2s ease,border-color .2s ease;width:100px}.thumbnail-image:hover{border-color:#2457d6;border-color:var(--accent-cyan);transform:translateY(-2px)}.thumbnail-image.active{border-color:#d95b43;border-color:var(--accent-magenta)}.project-details,.project-media-placeholder{background:#fffcf6bd;background:var(--card-bg);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:30px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft)}.project-media-placeholder{display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:420px;padding:2.4rem}.project-details h3,.project-media-placeholder h2{font-family:"Instrument Serif",serif;font-weight:400}.project-media-placeholder h2{font-size:2.5rem;line-height:.98}.project-media-placeholder p{line-height:1.9}.project-details{padding:2rem}.project-details h3{font-size:2.2rem;margin-bottom:1rem}.project-details p{font-size:1rem;line-height:1.95}.details-link{margin-top:1.4rem}.project-not-found{padding:5rem 1rem;text-align:center}.footer{border-top:1px solid #1c273814;color:#5d6472;color:var(--secondary-text-color);margin-top:4rem;padding:2.5rem 0;text-align:center}html[data-theme=cosmic] .footer{border-top-color:#ffffff14}.theme-lab{align-items:flex-end;bottom:1.15rem;display:flex;flex-direction:column;gap:.8rem;position:fixed;right:1.15rem;z-index:1100}.theme-lab-trigger{background:#fffcf6f0;background:var(--paper-strong);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:20px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);color:#1c2738;color:var(--primary-text-color);cursor:pointer;min-width:150px;padding:.95rem 1rem;text-align:left;transition:transform .2s ease,border-color .2s ease}.theme-lab-trigger:hover{border-color:#2457d6;border-color:var(--accent-cyan);transform:translateY(-2px)}.theme-lab-kicker,.theme-lab-trigger-label{color:#2457d6;color:var(--accent-cyan);display:block;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase}.theme-lab-trigger strong{display:block;font-family:"Instrument Serif",serif;font-size:1.5rem;font-weight:400;margin-top:.45rem}.theme-lab-drawer{background:#fffcf6f0;background:var(--paper-strong);border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:26px;box-shadow:0 18px 48px #1c273814;box-shadow:var(--shadow-soft);padding:1.4rem;position:relative;width:min(360px,calc(100vw - 2rem))}.theme-lab-close{background:#0000;border:none;color:#5d6472;color:var(--secondary-text-color);cursor:pointer;font-size:1.4rem;height:2rem;line-height:1;position:absolute;right:.9rem;top:.85rem;width:2rem}.theme-lab-close:hover{color:#1c2738;color:var(--primary-text-color)}.theme-lab-drawer h3{font-family:"Instrument Serif",serif;font-size:2rem;font-weight:400;line-height:.98;margin:.7rem 0 0}.theme-lab-note{color:#5d6472;color:var(--secondary-text-color);line-height:1.7;margin-top:.9rem}.theme-lab-actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1rem}.theme-lab-button{border:1px solid #1c27381f;border:1px solid var(--border-color);border-radius:999px;cursor:pointer;padding:.82rem 1rem;transition:transform .2s ease,border-color .2s ease}.theme-lab-button:hover{transform:translateY(-1px)}.theme-lab-button.primary{background:#1c2738;background:var(--primary-text-color);border-color:#1c2738;border-color:var(--primary-text-color);color:#fff7ee;color:var(--button-inverse-text)}@keyframes nav-glitch{0%,to{transform:translateY(0)}50%{transform:translateY(-1px)}}@keyframes subtle-text-glitch{0%{text-shadow:1px 0 #d95b4333,-1px 0 #2457d62e}to{text-shadow:-1px 0 #d95b4333,1px 0 #2457d62e}}@keyframes scan-line{0%{opacity:0}to{opacity:1}}@keyframes draw-border{0%{opacity:.8}to{opacity:1}}.glitch-wrapper{display:inline-block;position:relative}.glitch{color:var(--primary-text-color);letter-spacing:.01em;position:relative}.glitch:after,.glitch:before{content:attr(data-text);height:100%;left:0;opacity:.45;pointer-events:none;position:absolute;top:0;width:100%}.glitch:before{color:#2457d68c;transform:translate(-2px,-1px)}.glitch:after{color:#d95b4373;transform:translate(2px,1px)}.particles-bg{inset:0;overflow:hidden;position:absolute;z-index:-1}.particle{animation:rise 7s ease-in infinite;background:#2457d638;border-radius:999px;opacity:0;position:absolute}@keyframes rise{0%{opacity:0;transform:translateY(100vh) scale(.8)}20%{opacity:.65}to{opacity:0;transform:translateY(-15vh) scale(1.1)}}@media (max-width:768px){.navbar{padding-top:.8rem}.navbar-inner{align-items:center;border-radius:24px;padding:.9rem 1rem;position:relative;width:94%}.nav-logo{height:46px;width:46px}.nav-name{font-size:1.45rem}.nav-links{display:none}.nav-links.active{align-items:stretch;background:#fffcf6f5;border:1px solid var(--border-color);border-radius:24px;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:0;left:0;padding:.5rem;position:absolute;right:0;top:calc(100% + .75rem)}.nav-links.active a{border-radius:16px;margin:0;padding:.95rem 1rem;text-align:center}.hamburger-menu{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:28px}.hamburger-bar{background-color:var(--primary-text-color);border-radius:999px;height:2px;transition:all .3s ease-in-out;width:100%}.hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}.hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}.hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}body{font-size:14px}.hero{min-height:74vh;padding-top:2rem}.hero-content{border-radius:28px;padding:2.25rem 1.4rem}.hero-content h1{font-size:clamp(3rem,16vw,4.5rem)}.hero-content p{font-size:.96rem;line-height:1.85}.about-text,.featured-project-shell,.project-details,.project-media-placeholder,.skill-category,.system-detail-card{padding:1.4rem}.about-text h2,.featured-project-header h2,.skills-title,.timeline-title{font-size:clamp(2.2rem,12vw,3rem)}.system-selector{gap:.55rem}.system-selector-button{text-align:left;width:100%}.timeline-line{left:18px;transform:translateX(0)}.timeline-item,.timeline-item:nth-child(2n){left:0;padding-left:3.5rem;padding-right:0;text-align:left;width:100%}.timeline-dot,.timeline-item:nth-child(2n) .timeline-dot,.timeline-item:nth-child(odd) .timeline-dot{left:9px;right:auto}.timeline-project-title{font-size:1.7rem}.about-content{gap:1.6rem;grid-template-columns:1fr}.about-text{order:2}.about-image{max-width:250px;order:1}.skills-grid{grid-template-columns:1fr}.project-header h1{font-size:clamp(2.5rem,14vw,4rem)}.back-link{display:block;margin-bottom:1rem;text-align:center}.project-body.side-by-side{flex-direction:column}.project-body.side-by-side .project-details,.project-body.side-by-side .project-gallery{max-width:100%}.project-media-placeholder{min-height:320px}.featured-project-actions{flex-direction:column}.theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}.theme-lab-button,.theme-lab-drawer,.theme-lab-trigger{width:100%}.theme-lab-actions{flex-direction:column}}@media (min-width:769px){.hamburger-menu{display:none}}body{cursor:auto}.mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}.trail-particle{animation:fade-out .65s forwards;border-radius:50%;height:10px;opacity:.45;position:absolute;transform:translate(-50%,-50%);width:10px}@keyframes fade-out{0%{opacity:.45;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.4)}}.decrypt-wrapper{position:relative}.decrypt-layout-text{color:#0000;opacity:0;pointer-events:none}.decrypt-scramble-text{color:var(--accent-cyan);font-weight:500;inset:0;margin:0;position:absolute}.decrypt-wrapper p{margin-bottom:1rem}.decrypt-scramble-text:not(.decrypting){color:var(--secondary-text-color);font-weight:400}html[data-theme=cosmic]{--bg-color:#121212;--primary-text-color:#eaeaea;--secondary-text-color:#a5a5a5;--accent-cyan:#00fff9;--accent-magenta:#ff00c1;--border-color:#ffffff1a;--card-bg:#ffffff0d;--accent-cyan-glow:#00fff966}html[data-theme=cosmic] body{background:var(--bg-color);color:var(--primary-text-color);cursor:none;font-family:Space Mono,monospace;overflow-x:hidden}html[data-theme=cosmic] .navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#121212cc;border-bottom:1px solid var(--border-color);padding:0;position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:999}html[data-theme=cosmic] .navbar-inner{align-items:center;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border:none;border-radius:0;box-shadow:none;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:1rem 0;width:90%}html[data-theme=cosmic] .logo-title{gap:0}html[data-theme=cosmic] .nav-logo{background:#343942;border:1px solid #ffffff14;border-radius:16px;box-shadow:none;height:60px;margin-right:1rem;object-fit:cover;padding:.35rem;width:60px}html[data-theme=cosmic] .nav-name{color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:1.4rem;font-weight:700}html[data-theme=cosmic] .nav-links{align-items:center;display:flex;gap:0}html[data-theme=cosmic] .nav-links a{color:var(--primary-text-color);font-size:1rem;font-weight:400;letter-spacing:0;margin-left:2rem;position:relative;text-decoration:none;text-transform:none;transition:color .3s}html[data-theme=cosmic] .nav-links a:hover{animation:nav-glitch .3s linear;color:var(--accent-cyan);transform:none}html[data-theme=cosmic] .hero{align-items:center;display:flex;justify-content:center;min-height:85vh;padding:0;position:relative;text-align:center;width:100%}html[data-theme=cosmic] .hero-content:before,html[data-theme=cosmic] .hero:after,html[data-theme=cosmic] .hero:before{content:none}html[data-theme=cosmic] .hero-content{background:#0000;border:none;border-radius:0;box-shadow:none;color:#fff;margin:0 auto;max-width:800px;padding:2rem 1rem;width:90%;z-index:1}html[data-theme=cosmic] .hero-content h1{font-family:Space Mono,monospace;font-size:3.5rem;font-weight:700;line-height:1.1;margin-bottom:1.5rem}html[data-theme=cosmic] .hero-content p{color:var(--secondary-text-color);font-size:1.1rem;line-height:1.7;margin:0;max-width:none}html[data-theme=cosmic] .featured-project-section{margin:0 auto 5rem;max-width:1250px;width:90%}html[data-theme=cosmic] .featured-project-shell{background:radial-gradient(circle at top left,#00fff91a,#0000 32%),radial-gradient(circle at bottom right,#ff00c114,#0000 28%),#ffffff08;border:1px solid var(--border-color);border-radius:20px;box-shadow:none;padding:2.5rem}html[data-theme=cosmic] .featured-project-header,html[data-theme=cosmic] .featured-project-summary{margin-bottom:1.5rem}html[data-theme=cosmic] .featured-project-kicker,html[data-theme=cosmic] .project-media-kicker,html[data-theme=cosmic] .system-detail-kicker{color:var(--accent-cyan);display:inline-block;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}html[data-theme=cosmic] .featured-project-header h2{font-family:Space Mono,monospace;font-size:2.5rem;font-weight:700;line-height:1.1;margin:.7rem 0 .9rem}html[data-theme=cosmic] .about-text p,html[data-theme=cosmic] .contact-item,html[data-theme=cosmic] .featured-project-header p,html[data-theme=cosmic] .featured-project-summary p,html[data-theme=cosmic] .project-details p,html[data-theme=cosmic] .project-media-placeholder p,html[data-theme=cosmic] .system-detail-stack,html[data-theme=cosmic] .system-detail-summary,html[data-theme=cosmic] .timeline-project-preview{color:var(--secondary-text-color)}html[data-theme=cosmic] .featured-project-header p,html[data-theme=cosmic] .featured-project-summary p{line-height:1.8}html[data-theme=cosmic] .system-selector{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}html[data-theme=cosmic] .system-selector-button{background:#0000;border:1px solid var(--border-color);border-radius:999px;color:var(--secondary-text-color);cursor:pointer;font:inherit;padding:.7rem 1rem;transition:border-color .2s ease,color .2s ease,background .2s ease}html[data-theme=cosmic] .system-selector-button.active,html[data-theme=cosmic] .system-selector-button:hover{background:#ffffff0a;border-color:var(--accent-cyan);color:var(--primary-text-color);transform:none}html[data-theme=cosmic] .system-detail-card{background:#ffffff0a;border:1px solid var(--border-color);border-radius:16px;padding:1.6rem}html[data-theme=cosmic] .system-detail-topbar{margin-bottom:1rem}html[data-theme=cosmic] .system-detail-topbar h3{font-family:Space Mono,monospace;font-size:1.7rem;font-weight:700;line-height:1.2;margin-top:.45rem}html[data-theme=cosmic] .system-detail-stack,html[data-theme=cosmic] .system-detail-summary{line-height:1.8;margin-bottom:1rem}html[data-theme=cosmic] .system-detail-stack strong{color:var(--primary-text-color)}html[data-theme=cosmic] .system-log{display:flex;flex-direction:column;gap:.75rem}html[data-theme=cosmic] .system-log-line{align-items:flex-start;color:var(--secondary-text-color);display:flex;gap:.6rem;line-height:1.7}html[data-theme=cosmic] .system-log-prompt{color:var(--accent-cyan);line-height:1.7}html[data-theme=cosmic] .featured-project-actions{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-top:1.5rem}html[data-theme=cosmic] .featured-project-button,html[data-theme=cosmic] .project-live-link{align-items:center;border-radius:12px;display:inline-flex;font-weight:700;justify-content:center;padding:.85rem 1.15rem;text-decoration:none;transition:transform .2s ease,border-color .2s ease,color .2s ease}html[data-theme=cosmic] .featured-project-button:hover,html[data-theme=cosmic] .project-live-link:hover{transform:translateY(-2px)}html[data-theme=cosmic] .featured-project-button.primary,html[data-theme=cosmic] .project-live-link{background:var(--accent-cyan);border:none;color:#041414}html[data-theme=cosmic] .featured-project-button.secondary{background:#ffffff0a;border:1px solid #ffffff24;color:var(--primary-text-color)}html[data-theme=cosmic] .featured-project-button.secondary:hover{border-color:var(--accent-magenta);color:var(--accent-magenta)}html[data-theme=cosmic] .contact-container,html[data-theme=cosmic] .skills-container,html[data-theme=cosmic] .timeline-container{max-width:1200px;width:90%}html[data-theme=cosmic] .timeline-container{margin:4rem auto;position:relative}html[data-theme=cosmic] .about-text h2,html[data-theme=cosmic] .skills-title,html[data-theme=cosmic] .timeline-title{color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:2.2rem;font-weight:700;margin-bottom:3rem;text-align:center;transition:text-shadow .2s}html[data-theme=cosmic] .about-text h2:hover,html[data-theme=cosmic] .skills-title:hover,html[data-theme=cosmic] .timeline-title:hover{animation:subtle-text-glitch .4s steps(2) infinite}html[data-theme=cosmic] .timeline{position:relative}html[data-theme=cosmic] .timeline-line{background:var(--border-color);bottom:0;left:50%;position:absolute;top:0;transform:translateX(-50%);width:2px}html[data-theme=cosmic] .timeline-item{cursor:pointer;margin-bottom:2rem;padding:1rem 2rem;position:relative;width:50%}html[data-theme=cosmic] .timeline-item:nth-child(odd){left:0;padding-right:4rem;text-align:right}html[data-theme=cosmic] .timeline-item:nth-child(2n){left:50%;padding-left:4rem;text-align:left}html[data-theme=cosmic] .timeline-dot{background:var(--bg-color);border:3px solid var(--accent-cyan);border-radius:50%;height:14px;position:absolute;top:1rem;transition:background-color .3s;width:14px;z-index:1}html[data-theme=cosmic] .timeline-item:hover .timeline-dot{background:var(--accent-cyan);transform:none}html[data-theme=cosmic] .timeline-item:nth-child(odd) .timeline-dot{right:-7px}html[data-theme=cosmic] .timeline-item:nth-child(2n) .timeline-dot{left:-7px}html[data-theme=cosmic] .timeline-content{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:none;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}html[data-theme=cosmic] .timeline-content:before{content:none}html[data-theme=cosmic] .timeline-item:hover .timeline-content{border-color:var(--accent-cyan);box-shadow:0 0 20px var(--accent-cyan-glow);transform:translateY(-5px)}html[data-theme=cosmic] .timeline-content:after{background:var(--accent-cyan);box-shadow:0 0 10px var(--accent-cyan),0 0 20px var(--accent-cyan);content:"";height:3px;left:0;opacity:0;position:absolute;top:0;transform:translateY(0);transition:transform .28s cubic-bezier(.23,1,.32,1),opacity 0s linear;width:100%}html[data-theme=cosmic] .timeline-item:hover .timeline-content:after{opacity:.7;transform:translateY(18px)}html[data-theme=cosmic] .timeline-date{color:var(--accent-magenta);font-weight:700;margin-bottom:.5rem}html[data-theme=cosmic] .timeline-project-title{color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:1.4rem;font-weight:700;line-height:1.3;margin-bottom:.5rem}html[data-theme=cosmic] .timeline-project-preview{font-size:.9rem;line-height:1.5}html[data-theme=cosmic] .timeline-read-more{border-radius:0;color:var(--accent-cyan);display:block;font-weight:700;margin-top:.5rem;text-decoration:none}html[data-theme=cosmic] .about-container{background:var(--bg-color);padding:4rem 0}html[data-theme=cosmic] .about-content{align-items:center;display:flex;gap:3rem;margin:0 auto;max-width:1000px;width:90%}html[data-theme=cosmic] .about-text{background:#0000;border:none;border-radius:0;box-shadow:none;flex:2 1;padding:0}html[data-theme=cosmic] .about-text h2{text-align:left}html[data-theme=cosmic] .about-text p{line-height:1.7;margin-bottom:1rem}html[data-theme=cosmic] .about-image{flex:1 1;max-width:300px}html[data-theme=cosmic] .about-image img{background:#0000;border:2px solid var(--accent-cyan);border-radius:0;box-shadow:0 0 25px #00fff94d;-webkit-clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);filter:grayscale(100%);padding:0;transition:filter .4s ease-out,transform .4s ease-out;width:100%}html[data-theme=cosmic] .about-image:hover img{filter:grayscale(0);transform:rotate(-2deg) scale(1.05)}html[data-theme=cosmic] .skills-container{margin:4rem auto;text-align:center}html[data-theme=cosmic] .skills-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}html[data-theme=cosmic] .skill-category{background:var(--card-bg);border:1px solid #0000;border-radius:8px;box-shadow:none;padding:2rem;position:relative;text-align:left}html[data-theme=cosmic] .skill-category .border-svg{display:block;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}html[data-theme=cosmic] .skill-category .border-svg rect{fill:none;stroke:var(--border-color);stroke-width:1px;stroke-linecap:square;vector-effect:non-scaling-stroke;rx:8px;x:1px;y:1px;height:calc(100% - 2px);transition:stroke .3s;width:calc(100% - 2px)}html[data-theme=cosmic] .skill-category:hover .border-svg rect{stroke:var(--accent-magenta);stroke-dasharray:24 16;animation:cosmic-border-march 2.4s linear infinite}html[data-theme=cosmic] .skill-category h3{border-bottom:1px solid var(--border-color);color:var(--accent-magenta);font-family:Space Mono,monospace;font-size:1.5rem;font-weight:700;margin-bottom:1rem;padding-bottom:.5rem}html[data-theme=cosmic] .skill-category ul{display:block;list-style:none;padding:0}html[data-theme=cosmic] .skill-category li{background:#0003;border:none;border-radius:4px;color:var(--secondary-text-color);font-weight:400;margin-bottom:.5rem;padding:.5rem 1rem}html[data-theme=cosmic] .contact-container{margin:3rem auto}html[data-theme=cosmic] .terminal-container{background:#1e1e1e;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 20px #0006;font-family:Space Mono,monospace;margin:4rem auto;max-width:800px;width:90%}html[data-theme=cosmic] .terminal-header{align-items:center;background:#333;border-bottom:none;border-top-left-radius:7px;border-top-right-radius:7px;display:flex;padding:.75rem;position:relative}html[data-theme=cosmic] .terminal-header-dot.red{background:#ff5f56}html[data-theme=cosmic] .terminal-header-dot.yellow{background:#ffbd2e}html[data-theme=cosmic] .terminal-header-dot.green{background:#27c93f}html[data-theme=cosmic] .terminal-header span{color:var(--secondary-text-color);font-size:.9rem;left:50%;letter-spacing:0;position:absolute;text-transform:none;transform:translateX(-50%)}html[data-theme=cosmic] .terminal-body{color:var(--primary-text-color);cursor:text;height:400px;overflow-y:auto;padding:1.5rem}html[data-theme=cosmic] .terminal-line{word-wrap:break-word;line-height:1.6;margin:0;padding:0;white-space:pre-wrap}html[data-theme=cosmic] .terminal-line.success{color:#27c93f}html[data-theme=cosmic] .terminal-line.error{color:#ff5f56}html[data-theme=cosmic] .terminal-line.link a{color:var(--accent-cyan);text-decoration:underline;-webkit-text-decoration-color:var(--accent-cyan-glow);text-decoration-color:var(--accent-cyan-glow)}html[data-theme=cosmic] .terminal-line.link a:hover{color:var(--accent-magenta);-webkit-text-decoration-color:var(--accent-magenta);text-decoration-color:var(--accent-magenta)}html[data-theme=cosmic] .prompt-text{color:var(--accent-cyan)}html[data-theme=cosmic] .terminal-input{background:#0000;border:none;caret-color:var(--accent-cyan);color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:1em;margin:0;outline:none;padding:0;width:100%}html[data-theme=cosmic] .project-page-container{margin:0 auto;max-width:1000px;min-height:100vh;padding:2rem}html[data-theme=cosmic] .project-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;margin-bottom:2rem;padding-bottom:2rem;position:relative;text-align:center}html[data-theme=cosmic] .project-header h1{color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:2.8rem;line-height:1.2;margin-bottom:.5rem}html[data-theme=cosmic] .project-header span{color:var(--accent-magenta);font-size:1rem;font-weight:700;letter-spacing:0;text-transform:none}html[data-theme=cosmic] .project-body{display:flex;flex-direction:column;gap:2rem}html[data-theme=cosmic] .project-body.side-by-side{align-items:flex-start;flex-direction:row}html[data-theme=cosmic] .project-body.side-by-side .project-gallery{flex:1 1;max-width:45%}html[data-theme=cosmic] .project-body.side-by-side .project-details{flex:1.5 1}html[data-theme=cosmic] .back-link{color:var(--primary-text-color);font-weight:700;margin-bottom:1.5rem;position:static;text-decoration:none;transition:color .3s}html[data-theme=cosmic] .back-link:hover{color:var(--accent-cyan)}html[data-theme=cosmic] .project-gallery{margin-bottom:3rem}html[data-theme=cosmic] .main-image-container{margin:0 auto 1rem;max-width:700px;position:relative;width:80%}html[data-theme=cosmic] .main-image{background:#0000;border:2px solid var(--border-color);border-radius:0;box-shadow:none;-webkit-clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);height:auto;transition:all .3s ease-in-out;width:100%}html[data-theme=cosmic] .main-image-container:hover .main-image{border-color:var(--accent-magenta);box-shadow:0 0 25px #ff00c180;transform:scale(1.02)}html[data-theme=cosmic] .thumbnail-container{display:flex;flex-wrap:nowrap;gap:1rem;justify-content:center}html[data-theme=cosmic] .thumbnail-image{border:2px solid #0000;border-radius:0;-webkit-clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);cursor:pointer;height:75px;object-fit:cover;transition:border-color .3s,transform .3s;width:100px}html[data-theme=cosmic] .thumbnail-image:hover{border-color:var(--accent-cyan);transform:scale(1.05)}html[data-theme=cosmic] .thumbnail-image.active{border-color:var(--accent-magenta);box-shadow:0 0 15px var(--accent-magenta)}html[data-theme=cosmic] .main-video{aspect-ratio:16/9;background:#000;border:2px solid var(--border-color);border-radius:0;box-shadow:none;-webkit-clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);clip-path:polygon(0 15%,15% 0,100% 0,85% 100%,0 100%);display:block;transition:all .3s ease-in-out;width:100%}html[data-theme=cosmic] .main-image-container:hover .main-video{border-color:var(--accent-magenta);box-shadow:0 0 25px #ff00c180}html[data-theme=cosmic] .project-media-placeholder{align-items:flex-start;background:radial-gradient(circle at top left,#00fff924,#0000 35%),radial-gradient(circle at bottom right,#ff00c11f,#0000 30%),#0a0a0acc;border:1px solid #00fff938;border-radius:20px;box-shadow:0 0 24px #00fff91a;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:420px;padding:2.5rem;text-align:left;width:100%}html[data-theme=cosmic] .project-media-placeholder h2{font-family:Space Mono,monospace;font-size:2rem;font-weight:700;line-height:1.2}html[data-theme=cosmic] .project-details{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:none;padding:2rem}html[data-theme=cosmic] .project-details h3{color:var(--primary-text-color);font-family:Space Mono,monospace;font-size:1.8rem;font-weight:700;margin-bottom:1rem}html[data-theme=cosmic] .project-details p{font-size:1.1rem;line-height:1.8}html[data-theme=cosmic] .details-link{margin-top:1.5rem}html[data-theme=cosmic] .project-not-found{padding:5rem 1rem;text-align:center}html[data-theme=cosmic] .footer{background:var(--bg-color);border-top:1px solid var(--border-color);color:var(--secondary-text-color);margin-top:3rem;padding:2rem 0;text-align:center}html[data-theme=cosmic] .glitch-wrapper{display:inline-block;position:relative}html[data-theme=cosmic] .glitch{color:#fff;letter-spacing:0;mix-blend-mode:screen;position:relative}html[data-theme=cosmic] .glitch:after,html[data-theme=cosmic] .glitch:before{background:#121212;-webkit-clip-path:inset(50% 50% 50% 50%);clip-path:inset(50% 50% 50% 50%);content:attr(data-text);height:100%;left:0;opacity:1;overflow:hidden;position:absolute;top:0;width:100%}html[data-theme=cosmic] .glitch:before{animation:cosmic-glitch-anim-1 2.5s linear infinite alternate-reverse;color:inherit;left:-2px;text-shadow:-1px 0 #ff00c1}html[data-theme=cosmic] .glitch:after{animation:cosmic-glitch-anim-2 2s linear infinite alternate-reverse;color:inherit;left:2px;text-shadow:-1px 0 #00fff9}html[data-theme=cosmic] .particles-bg{height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%;z-index:-1}html[data-theme=cosmic] .particle{animation:cosmic-rise 5s ease-in infinite;background-color:#00fff9;border-radius:50%;opacity:0;position:absolute}html[data-theme=cosmic] .mouse-trail-container{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:9999}html[data-theme=cosmic] .trail-particle{animation:cosmic-fade-out .5s forwards;border-radius:0;height:8px;opacity:1;position:absolute;transform:translate(-50%,-50%);width:8px}html[data-theme=cosmic] .decrypt-scramble-text{color:var(--accent-cyan);font-weight:700}html[data-theme=cosmic] .decrypt-scramble-text:not(.decrypting){color:var(--secondary-text-color);font-weight:400}@keyframes cosmic-glitch-anim-1{0%{-webkit-clip-path:inset(40% 0 60% 0);clip-path:inset(40% 0 60% 0)}20%{-webkit-clip-path:inset(10% 0 85% 0);clip-path:inset(10% 0 85% 0)}40%{-webkit-clip-path:inset(50% 0 30% 0);clip-path:inset(50% 0 30% 0)}60%{-webkit-clip-path:inset(30% 0 70% 0);clip-path:inset(30% 0 70% 0)}80%{-webkit-clip-path:inset(80% 0 5% 0);clip-path:inset(80% 0 5% 0)}to{-webkit-clip-path:inset(60% 0 40% 0);clip-path:inset(60% 0 40% 0)}}@keyframes cosmic-glitch-anim-2{0%{-webkit-clip-path:inset(2% 0 98% 0);clip-path:inset(2% 0 98% 0)}20%{-webkit-clip-path:inset(90% 0 2% 0);clip-path:inset(90% 0 2% 0)}40%{-webkit-clip-path:inset(45% 0 45% 0);clip-path:inset(45% 0 45% 0)}60%{-webkit-clip-path:inset(95% 0 5% 0);clip-path:inset(95% 0 5% 0)}80%{-webkit-clip-path:inset(10% 0 80% 0);clip-path:inset(10% 0 80% 0)}to{-webkit-clip-path:inset(0 0 100% 0);clip-path:inset(0 0 100% 0)}}@keyframes cosmic-rise{0%{opacity:1;transform:translateY(100vh) scale(.5)}50%{opacity:.8}to{opacity:0;transform:translateY(-10vh) scale(1)}}@keyframes cosmic-fade-out{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(0)}}@keyframes cosmic-border-march{0%{stroke-dashoffset:0}to{stroke-dashoffset:-104}}@media (max-width:768px){html[data-theme=cosmic] .navbar-inner{align-items:center;flex-direction:row;justify-content:space-between;padding:.75rem 1rem;position:relative;width:100%}html[data-theme=cosmic] .nav-links{display:none}html[data-theme=cosmic] .nav-links.active{background:#222;border-radius:0;border-top:2px solid #ddd;box-shadow:none;display:flex;flex-direction:column;left:0;padding:0;position:absolute;right:0;top:100%;z-index:1000}html[data-theme=cosmic] .nav-links.active a{border-bottom:1px solid #444;border-radius:0;margin:0;padding:1.2rem 1rem;text-align:center;width:100%}html[data-theme=cosmic] .nav-links.active a:last-child{border-bottom:none}html[data-theme=cosmic] .hamburger-menu{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:25px;justify-content:space-around;padding:0;width:30px}html[data-theme=cosmic] .hamburger-bar{background-color:#fff;border-radius:2px;height:3px;transition:all .3s ease-in-out;width:100%}html[data-theme=cosmic] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=cosmic] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=cosmic] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=cosmic] body{font-size:14px}html[data-theme=cosmic] h1{font-size:2.2rem}html[data-theme=cosmic] h2{font-size:1.8rem}html[data-theme=cosmic] .hero{min-height:70vh}html[data-theme=cosmic] .hero-content h1{font-size:2.5rem}html[data-theme=cosmic] .hero-content p{font-size:1rem}html[data-theme=cosmic] .featured-project-shell{padding:1.5rem}html[data-theme=cosmic] .featured-project-header h2{font-size:2rem}html[data-theme=cosmic] .system-selector{gap:.6rem}html[data-theme=cosmic] .system-selector-button{text-align:left;width:100%}html[data-theme=cosmic] .system-detail-card{padding:1.25rem}html[data-theme=cosmic] .timeline-line{left:20px;transform:translateX(0)}html[data-theme=cosmic] .timeline-item,html[data-theme=cosmic] .timeline-item:nth-child(2n){left:0;padding-left:4rem;padding-right:1rem;text-align:left;width:100%}html[data-theme=cosmic] .timeline-dot,html[data-theme=cosmic] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=cosmic] .timeline-item:nth-child(odd) .timeline-dot{left:12px;right:auto}html[data-theme=cosmic] .about-content{flex-direction:column;gap:2rem;text-align:center}html[data-theme=cosmic] .about-text{order:2}html[data-theme=cosmic] .about-image{max-width:250px;order:1}html[data-theme=cosmic] .skills-grid{grid-template-columns:1fr}html[data-theme=cosmic] .project-header h1{font-size:2rem}html[data-theme=cosmic] .back-link{display:block;margin-bottom:1rem;position:static;text-align:center}html[data-theme=cosmic] .project-body.side-by-side{flex-direction:column}html[data-theme=cosmic] .project-body.side-by-side .project-details,html[data-theme=cosmic] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=cosmic] .project-media-placeholder{min-height:300px;padding:1.5rem}}@media (min-width:769px){html[data-theme=cosmic] .hamburger-menu{display:none}}html[data-theme=brutalist]{--bg-color:#f3efe3;--primary-text-color:#111;--secondary-text-color:#3f3a34;--accent-cyan:#2155ff;--accent-magenta:#ff4f36;--accent-gold:#ffd200;--border-color:#111;--card-bg:#fffaf1;--paper-color:#fffaf1;--paper-strong:#fffdf7;--accent-cyan-glow:#2155ff2e;--shadow-soft:10px 10px 0 #111;--logo-badge-bg:#2f3138;--logo-badge-border:#111;--nav-shell-bg:#fffaf1;--nav-wash:#0000;--hero-shell-bg:#fffaf1;--button-inverse-text:#fff7f0;--ghost-pill-bg:#fffaf1;--ghost-button-bg:#fffaf1;--surface-strong-bg:#fffaf1;--surface-soft-bg:#fffaf1;--inner-highlight:#0000}html[data-theme=brutalist] body{background:linear-gradient(90deg,#11111114 2px,#0000 2px),linear-gradient(#11111114 2px,#0000 2px),linear-gradient(16deg,#ffd20033 0 12%,#0000 12% 100%),linear-gradient(-16deg,#2155ff29 0 10%,#0000 10% 100%),radial-gradient(circle at 14% 18%,#ff4f363d,#0000 12%),radial-gradient(circle at 84% 22%,#ffd2003d,#0000 11%),radial-gradient(circle at 24% 78%,#2155ff2e,#0000 12%),var(--bg-color);background-size:52px 52px,52px 52px,auto,auto,auto,auto,auto,auto;cursor:none;font-family:IBM Plex Mono,monospace}html[data-theme=brutalist] .navbar{background:#0000;padding:.9rem 0 0}html[data-theme=brutalist] .navbar-inner{-webkit-backdrop-filter:none;backdrop-filter:none;background:var(--nav-shell-bg);border:3px solid var(--border-color);border-radius:0;box-shadow:8px 8px 0 var(--accent-gold);padding:1rem 1.2rem;width:min(94%,1260px)}html[data-theme=brutalist] .logo-title{gap:1rem}html[data-theme=brutalist] .nav-logo{background:var(--logo-badge-bg);border:3px solid var(--border-color);border-radius:0;box-shadow:5px 5px 0 var(--accent-cyan);height:64px;margin-right:0;padding:.4rem;width:64px}html[data-theme=brutalist] .nav-name{font-family:Archivo Black,sans-serif;font-size:1.55rem;letter-spacing:.02em;text-transform:uppercase}html[data-theme=brutalist] .nav-links{gap:.75rem}html[data-theme=brutalist] .nav-links a{background:#0000;border:2px solid #0000;font-size:.84rem;font-weight:700;letter-spacing:.08em;margin-left:0;padding:.55rem .8rem;text-transform:uppercase}html[data-theme=brutalist] .nav-links a:hover{animation:none;background:var(--accent-gold);border-color:var(--border-color);color:var(--primary-text-color);transform:translate(-2px,-2px)}html[data-theme=brutalist] .hero{min-height:88vh;padding:2rem 0 3rem}html[data-theme=brutalist] .hero:before{background:var(--accent-gold);border-radius:0;filter:none;height:18rem;left:4%;top:2rem;transform:rotate(-6deg);width:18rem}html[data-theme=brutalist] .hero:after{background:var(--accent-magenta);border-radius:0;bottom:10%;filter:none;height:11rem;right:8%;transform:rotate(8deg);width:11rem}html[data-theme=brutalist] .hero-content{background:var(--hero-shell-bg);border:4px solid var(--border-color);border-radius:0;box-shadow:14px 14px 0 var(--accent-cyan);padding:3.25rem 2.4rem 2.2rem;text-align:left;width:min(92%,1040px)}html[data-theme=brutalist] .hero-content:before{background:var(--accent-gold);border:2px solid var(--border-color);color:var(--primary-text-color);content:"DESIGN + CODE + HARDWARE";display:inline-block;font-size:.84rem;letter-spacing:.08em;margin-bottom:1.5rem;padding:.45rem .65rem;text-transform:uppercase}html[data-theme=brutalist] .hero-content:after{background:var(--accent-magenta);border:2px solid var(--border-color);color:#fff7f0;content:"LIVE PORTFOLIO";font-size:.78rem;letter-spacing:.1em;padding:.55rem .75rem;position:absolute;right:1.2rem;top:-1.2rem;transform:rotate(2deg)}html[data-theme=brutalist] .hero-content h1{font-family:Archivo Black,sans-serif;font-size:clamp(3.5rem,9vw,6.8rem);letter-spacing:-.03em;line-height:.92;margin-bottom:1.25rem;text-transform:uppercase}html[data-theme=brutalist] .hero-content p{font-size:1rem;line-height:1.85;margin:0;max-width:760px}html[data-theme=brutalist] .glitch{color:var(--primary-text-color);mix-blend-mode:normal}html[data-theme=brutalist] .glitch:after,html[data-theme=brutalist] .glitch:before{background:#0000;-webkit-clip-path:none;clip-path:none;opacity:1;overflow:visible}html[data-theme=brutalist] .glitch:before{animation:none;color:var(--accent-cyan);left:-4px;text-shadow:none}html[data-theme=brutalist] .glitch:after{animation:none;color:var(--accent-magenta);left:4px;text-shadow:none}html[data-theme=brutalist] .particles-bg{z-index:-1}html[data-theme=brutalist] .particle{animation:brutal-rise 7s linear infinite;background-color:var(--accent-cyan);border-radius:0;opacity:.22}html[data-theme=brutalist] .mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}html[data-theme=brutalist] .trail-particle{animation:brutal-trail-fade .55s forwards;border:2px solid var(--border-color);border-radius:0;box-shadow:3px 3px 0 var(--accent-gold);height:14px;position:absolute;transform:translate(-50%,-50%) rotate(8deg);width:14px}html[data-theme=brutalist] .contact-container,html[data-theme=brutalist] .featured-project-section,html[data-theme=brutalist] .skills-container,html[data-theme=brutalist] .timeline-container{width:min(94%,1260px)}html[data-theme=brutalist] .featured-project-shell{background:var(--paper-color);border:4px solid var(--border-color);border-radius:0;box-shadow:14px 14px 0 var(--accent-magenta);padding:2.6rem;position:relative}html[data-theme=brutalist] .featured-project-shell:before{background:var(--accent-gold);border:2px solid var(--border-color);content:"STAR PROJECT";font-size:.8rem;font-weight:700;left:1.2rem;letter-spacing:.08em;padding:.45rem .7rem;position:absolute;text-transform:uppercase;top:-1rem}html[data-theme=brutalist] .about-text h2,html[data-theme=brutalist] .featured-project-header h2,html[data-theme=brutalist] .project-details h3,html[data-theme=brutalist] .project-header h1,html[data-theme=brutalist] .project-media-placeholder h2,html[data-theme=brutalist] .skill-category h3,html[data-theme=brutalist] .skills-title,html[data-theme=brutalist] .system-detail-topbar h3,html[data-theme=brutalist] .theme-lab-drawer h3,html[data-theme=brutalist] .theme-lab-trigger strong,html[data-theme=brutalist] .timeline-title{font-family:Archivo Black,sans-serif;letter-spacing:-.03em;text-transform:uppercase}html[data-theme=brutalist] .featured-project-kicker,html[data-theme=brutalist] .project-header span,html[data-theme=brutalist] .project-media-kicker,html[data-theme=brutalist] .theme-lab-trigger-label,html[data-theme=brutalist] .timeline-date{background:var(--accent-gold);border:2px solid var(--border-color);color:var(--primary-text-color);letter-spacing:.08em;padding:.28rem .48rem}html[data-theme=brutalist] .featured-project-header h2{font-size:clamp(2.7rem,5.6vw,4.7rem);line-height:.95}html[data-theme=brutalist] .system-selector-button{background:var(--paper-strong);border:3px solid var(--border-color);border-radius:0;box-shadow:4px 4px 0 #0000;color:var(--primary-text-color);font-weight:700;letter-spacing:.04em;padding:.85rem 1rem;text-transform:uppercase}html[data-theme=brutalist] .system-selector-button.active,html[data-theme=brutalist] .system-selector-button:hover{background:var(--accent-cyan);border-color:var(--border-color);box-shadow:5px 5px 0 var(--accent-magenta);color:var(--primary-text-color);transform:translate(-3px,-3px)}html[data-theme=brutalist] .about-text,html[data-theme=brutalist] .project-details,html[data-theme=brutalist] .project-media-placeholder,html[data-theme=brutalist] .skill-category,html[data-theme=brutalist] .system-detail-card,html[data-theme=brutalist] .terminal-container,html[data-theme=brutalist] .theme-lab-drawer,html[data-theme=brutalist] .theme-lab-trigger{background:var(--paper-strong);border:4px solid var(--border-color);border-radius:0;box-shadow:10px 10px 0 var(--accent-cyan)}html[data-theme=brutalist] .system-detail-card{position:relative}html[data-theme=brutalist] .system-detail-card:after{background:var(--accent-magenta);border:2px solid var(--border-color);color:#fff7f0;content:"FULL STACK";font-size:.74rem;letter-spacing:.08em;padding:.35rem .5rem;position:absolute;right:1rem;top:1rem;transform:rotate(2deg)}html[data-theme=brutalist] .system-log-line{gap:.8rem}html[data-theme=brutalist] .system-log-prompt{background:var(--accent-gold);border:2px solid var(--border-color);color:var(--primary-text-color);font-weight:700;min-width:1.5rem;padding:.05rem .3rem;text-align:center}html[data-theme=brutalist] .featured-project-button,html[data-theme=brutalist] .project-live-link,html[data-theme=brutalist] .theme-lab-button{border:3px solid var(--border-color);border-radius:0;font-weight:700;letter-spacing:.05em;padding:.95rem 1.15rem;text-transform:uppercase}html[data-theme=brutalist] .featured-project-button.primary,html[data-theme=brutalist] .project-live-link,html[data-theme=brutalist] .theme-lab-button.primary{background:var(--accent-gold);color:var(--primary-text-color)}html[data-theme=brutalist] .featured-project-button.secondary{background:var(--accent-cyan);color:var(--primary-text-color)}html[data-theme=brutalist] .featured-project-button:hover,html[data-theme=brutalist] .project-live-link:hover,html[data-theme=brutalist] .theme-lab-button:hover{box-shadow:6px 6px 0 var(--accent-magenta);transform:translate(-4px,-4px)}html[data-theme=brutalist] .timeline{counter-reset:brutal-counter}html[data-theme=brutalist] .timeline-item{counter-increment:brutal-counter}html[data-theme=brutalist] .about-text h2,html[data-theme=brutalist] .skills-title,html[data-theme=brutalist] .timeline-title{font-size:clamp(2.6rem,5vw,4rem);margin-bottom:2rem;text-align:left}html[data-theme=brutalist] .skills-title,html[data-theme=brutalist] .timeline-title{position:relative}html[data-theme=brutalist] .skills-title:after,html[data-theme=brutalist] .timeline-title:after{background:var(--accent-cyan);border:2px solid var(--border-color);content:"";display:block;height:14px;margin-top:.6rem;width:100px}html[data-theme=brutalist] .timeline-line{background:var(--border-color);width:4px}html[data-theme=brutalist] .timeline-dot{background:var(--accent-gold);border:3px solid var(--border-color);height:18px;width:18px}html[data-theme=brutalist] .timeline-content{background:var(--card-bg);border:4px solid var(--border-color);border-radius:0;box-shadow:10px 10px 0 var(--accent-cyan);overflow:visible;padding:2rem 1.4rem 1.4rem;position:relative}html[data-theme=brutalist] .timeline-content:before{background:#0000;color:var(--accent-magenta);content:counter(brutal-counter,decimal-leading-zero);font-family:Archivo Black,sans-serif;font-size:3rem;left:auto;line-height:1;padding:0;position:absolute;right:1rem;top:-1.2rem}html[data-theme=brutalist] .timeline-content:after{animation:none;background:var(--accent-gold);border:2px solid var(--border-color);box-shadow:none;content:"";height:16px;left:1rem;opacity:1;position:absolute;top:-.8rem;width:84px}html[data-theme=brutalist] .timeline-item:nth-child(2n) .timeline-content:before{left:auto;right:1rem}html[data-theme=brutalist] .timeline-item:hover .timeline-content{border-color:var(--border-color);box-shadow:14px 14px 0 var(--accent-magenta);transform:translate(-4px,-4px)}html[data-theme=brutalist] .timeline-item:nth-child(2n):hover .timeline-content{box-shadow:14px 14px 0 var(--accent-cyan)}html[data-theme=brutalist] .timeline-project-title{font-family:Archivo Black,sans-serif;font-size:1.9rem;line-height:.98}html[data-theme=brutalist] .about-content{align-items:stretch;gap:2rem}html[data-theme=brutalist] .about-text{padding:2.1rem;position:relative}html[data-theme=brutalist] .about-text:after{background:var(--accent-magenta);border:2px solid var(--border-color);color:#fff7f0;content:"ABOUT";font-size:.78rem;left:1rem;letter-spacing:.08em;padding:.35rem .55rem;position:absolute;top:-.95rem;transform:rotate(-2deg)}html[data-theme=brutalist] .about-image{justify-self:center;max-width:360px;position:relative}html[data-theme=brutalist] .about-image:before{background:var(--accent-cyan);border:3px solid var(--border-color);content:"";inset:1rem -1rem -1rem 1rem;position:absolute;z-index:0}html[data-theme=brutalist] .about-image img{background:#fff;border:4px solid var(--border-color);border-radius:0;box-shadow:10px 10px 0 var(--accent-gold);-webkit-clip-path:none;clip-path:none;padding:0;position:relative;width:100%;z-index:1}html[data-theme=brutalist] .about-image:hover img{transform:translate(-4px,-4px) rotate(-1deg)}html[data-theme=brutalist] .skills-grid{gap:1.3rem}html[data-theme=brutalist] .skill-category{padding:1.5rem;transition:transform .2s ease,box-shadow .2s ease}html[data-theme=brutalist] .skill-category:nth-child(2){box-shadow:10px 10px 0 var(--accent-gold)}html[data-theme=brutalist] .skill-category:nth-child(3){box-shadow:10px 10px 0 var(--accent-magenta)}html[data-theme=brutalist] .skill-category:hover{transform:translate(-4px,-4px)}html[data-theme=brutalist] .skill-category .border-svg{display:none}html[data-theme=brutalist] .skill-category h3{font-size:1.9rem;margin-bottom:1rem}html[data-theme=brutalist] .skill-category ul{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(2,minmax(0,1fr))}html[data-theme=brutalist] .skill-category li{background:#fff;border:2px solid var(--border-color);border-radius:0;color:var(--primary-text-color);font-size:.82rem;margin:0;padding:.65rem .75rem}html[data-theme=brutalist] .terminal-container{background:#fffaf1;max-width:1040px}html[data-theme=brutalist] .terminal-header{background:var(--accent-gold);border-bottom:3px solid var(--border-color);padding:.8rem 1rem}html[data-theme=brutalist] .terminal-header-dot.red{background:var(--accent-magenta)}html[data-theme=brutalist] .terminal-header-dot.yellow{background:var(--accent-cyan)}html[data-theme=brutalist] .terminal-header-dot.green{background:var(--primary-text-color)}html[data-theme=brutalist] .terminal-header span{color:var(--primary-text-color);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}html[data-theme=brutalist] .contact-item a,html[data-theme=brutalist] .terminal-line.link a{color:var(--accent-magenta);text-decoration:underline;text-decoration-thickness:2px}html[data-theme=brutalist] .contact-item a:hover,html[data-theme=brutalist] .terminal-line.link a:hover{color:var(--accent-cyan)}html[data-theme=brutalist] .project-page-container{padding:2rem 0 4rem;width:min(94%,1180px)}html[data-theme=brutalist] .project-header{align-items:flex-start;padding:0 0 2rem;text-align:left}html[data-theme=brutalist] .project-header h1{font-size:clamp(3rem,8vw,5.8rem);line-height:.92}html[data-theme=brutalist] .project-header span{margin-top:.2rem}html[data-theme=brutalist] .project-body.side-by-side{gap:1.6rem}html[data-theme=brutalist] .main-image-container{margin:0 auto 1rem;max-width:760px;width:100%}html[data-theme=brutalist] .main-image,html[data-theme=brutalist] .main-video,html[data-theme=brutalist] .thumbnail-image{background:#fff;border-radius:0}html[data-theme=brutalist] .main-image,html[data-theme=brutalist] .main-video{border:4px solid var(--border-color);box-shadow:10px 10px 0 var(--accent-gold)}html[data-theme=brutalist] .main-image,html[data-theme=brutalist] .main-video{-webkit-clip-path:none;clip-path:none}html[data-theme=brutalist] .main-image-container:hover .main-image,html[data-theme=brutalist] .main-image-container:hover .main-video{box-shadow:14px 14px 0 var(--accent-magenta);transform:translate(-4px,-4px)}html[data-theme=brutalist] .thumbnail-container{flex-wrap:wrap;gap:.7rem}html[data-theme=brutalist] .thumbnail-image{border:3px solid var(--border-color);padding:0}html[data-theme=brutalist] .thumbnail-image:hover{border-color:var(--border-color);transform:translate(-3px,-3px)}html[data-theme=brutalist] .thumbnail-image.active{border-color:var(--border-color);box-shadow:6px 6px 0 var(--accent-cyan)}html[data-theme=brutalist] .project-details,html[data-theme=brutalist] .project-media-placeholder{padding:1.8rem}html[data-theme=brutalist] .project-media-placeholder{background:linear-gradient(135deg,#ffd20029,#0000 35%),var(--paper-color);gap:1rem;min-height:420px}html[data-theme=brutalist] .project-media-placeholder h2{font-size:2.2rem;line-height:1}html[data-theme=brutalist] .project-details h3{font-size:2.1rem}html[data-theme=brutalist] .theme-lab-trigger{box-shadow:8px 8px 0 var(--accent-magenta);min-width:170px;padding:.9rem 1rem}html[data-theme=brutalist] .theme-lab-trigger-label{display:inline-block}html[data-theme=brutalist] .theme-lab-trigger strong{font-size:1.3rem;margin-top:.4rem}html[data-theme=brutalist] .theme-lab-drawer{box-shadow:10px 10px 0 var(--accent-cyan);padding:1.25rem;width:min(380px,calc(100vw - 2rem))}html[data-theme=brutalist] .theme-lab-drawer h3{font-size:2rem;line-height:.96;margin-right:2rem}html[data-theme=brutalist] .theme-lab-close{color:var(--primary-text-color)}html[data-theme=brutalist] .theme-lab-close:hover{color:var(--accent-magenta)}html[data-theme=brutalist] .footer{background:#0000;border-top:4px solid var(--border-color);color:var(--primary-text-color)}@keyframes brutal-rise{0%{opacity:0;transform:translateY(100vh) rotate(0deg) scale(.8)}20%{opacity:.28}to{opacity:0;transform:translateY(-12vh) rotate(180deg) scale(1.15)}}@keyframes brutal-trail-fade{0%{opacity:.9;transform:translate(-50%,-50%) rotate(8deg) scale(1)}to{opacity:0;transform:translate(-50%,-50%) rotate(18deg) scale(.45)}}@media (max-width:768px){html[data-theme=brutalist] .navbar{padding-top:.8rem}html[data-theme=brutalist] .navbar-inner{box-shadow:6px 6px 0 var(--accent-gold);padding:.85rem 1rem;position:relative;width:95%}html[data-theme=brutalist] .nav-links{display:none}html[data-theme=brutalist] .nav-links.active{align-items:stretch;background:var(--paper-strong);border:3px solid var(--border-color);box-shadow:7px 7px 0 var(--accent-magenta);display:flex;flex-direction:column;gap:.5rem;left:0;padding:.8rem;position:absolute;right:0;top:calc(100% + .7rem);z-index:1000}html[data-theme=brutalist] .nav-links.active a{background:#fff;border:2px solid var(--border-color);padding:.9rem 1rem;text-align:center;width:100%}html[data-theme=brutalist] .hamburger-menu{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:25px;justify-content:space-around;padding:0;width:30px}html[data-theme=brutalist] .hamburger-bar{background-color:var(--primary-text-color);border-radius:0;height:3px;transition:all .3s ease-in-out;width:100%}html[data-theme=brutalist] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=brutalist] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=brutalist] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=brutalist] .hero{min-height:auto;padding:2rem 0 2.5rem}html[data-theme=brutalist] .hero-content{box-shadow:8px 8px 0 var(--accent-cyan);padding:2rem 1.2rem 1.4rem;width:94%}html[data-theme=brutalist] .hero-content:after{display:inline-block;margin-top:1rem;position:static}html[data-theme=brutalist] .hero-content h1{font-size:clamp(2.8rem,15vw,4.4rem)}html[data-theme=brutalist] .about-text,html[data-theme=brutalist] .featured-project-shell,html[data-theme=brutalist] .project-details,html[data-theme=brutalist] .project-media-placeholder,html[data-theme=brutalist] .skill-category,html[data-theme=brutalist] .system-detail-card,html[data-theme=brutalist] .terminal-container{box-shadow:7px 7px 0 var(--accent-cyan);padding:1.3rem}html[data-theme=brutalist] .about-text h2,html[data-theme=brutalist] .featured-project-header h2,html[data-theme=brutalist] .skills-title,html[data-theme=brutalist] .timeline-title{font-size:clamp(2.1rem,12vw,3rem);text-align:left}html[data-theme=brutalist] .timeline-line{left:18px;transform:translateX(0)}html[data-theme=brutalist] .timeline-item,html[data-theme=brutalist] .timeline-item:nth-child(2n){left:0;padding-left:3.4rem;padding-right:0;text-align:left;width:100%}html[data-theme=brutalist] .timeline-dot,html[data-theme=brutalist] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=brutalist] .timeline-item:nth-child(odd) .timeline-dot{left:9px;right:auto}html[data-theme=brutalist] .timeline-content:before{font-size:2.2rem;top:-.9rem}html[data-theme=brutalist] .about-content{gap:1.4rem;grid-template-columns:1fr}html[data-theme=brutalist] .about-image{max-width:260px;order:1}html[data-theme=brutalist] .about-text{order:2}html[data-theme=brutalist] .skill-category ul{grid-template-columns:1fr}html[data-theme=brutalist] .project-header{align-items:flex-start}html[data-theme=brutalist] .project-header h1{font-size:clamp(2.6rem,13vw,4.1rem)}html[data-theme=brutalist] .back-link{display:inline-block;margin-bottom:1rem;text-align:left}html[data-theme=brutalist] .project-body.side-by-side{flex-direction:column}html[data-theme=brutalist] .project-body.side-by-side .project-details,html[data-theme=brutalist] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=brutalist] .featured-project-actions,html[data-theme=brutalist] .theme-lab-actions{flex-direction:column}html[data-theme=brutalist] .theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}html[data-theme=brutalist] .theme-lab-button,html[data-theme=brutalist] .theme-lab-drawer,html[data-theme=brutalist] .theme-lab-trigger{width:100%}}@media (min-width:769px){html[data-theme=brutalist] .hamburger-menu{display:none}}html[data-theme=sunset]{--bg-color:#fff0e5;--paper-color:#fff5ecc7;--paper-strong:#fff9f4e6;--primary-text-color:#553749;--secondary-text-color:#886673;--accent-cyan:#d86f53;--accent-magenta:#7c4f69;--accent-gold:#f3b36b;--border-color:#7c4f6924;--card-bg:#fff8f2b3;--accent-cyan-glow:#d86f5347;--shadow-soft:0 24px 70px #7f4d5e1f;--logo-badge-bg:#56404b;--logo-badge-border:#fff3;--nav-shell-bg:#fffaf69e;--nav-wash:linear-gradient(180deg,#fff0e5f2,#fff0e5bd 68%,#0000);--hero-shell-bg:linear-gradient(140deg,#fffbf6d6,#ffe9dd9e);--button-inverse-text:#fff8f2;--ghost-pill-bg:#fff6;--ghost-button-bg:#ffffff61;--surface-strong-bg:#ffffff9e;--surface-soft-bg:#ffffff6b;--inner-highlight:#ffffff6b}html[data-theme=sunset] body{background-color:#ffeede;background:radial-gradient(circle at 78% 12%,#f3b36b6b,#0000 18%),radial-gradient(circle at 20% 16%,#7c4f691a,#0000 22%),linear-gradient(180deg,#fff7ef,#ffeede 34%,#ffd9c7 72%,#f6b79a);color:var(--primary-text-color);font-family:Manrope,sans-serif}html[data-theme=sunset] .navbar{background:var(--nav-wash);padding-top:1rem}html[data-theme=sunset] .navbar-inner{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:linear-gradient(180deg,#ffffff94,#fff6ef6b),var(--nav-shell-bg);border:1px solid #7c4f691f;border-radius:24px;box-shadow:0 18px 50px #7c4f691a;padding:.95rem 1.15rem;width:min(94%,1220px)}html[data-theme=sunset] .logo-title{gap:.9rem}html[data-theme=sunset] .nav-logo{background:radial-gradient(circle at 30% 30%,#ffffff2e,#0000 42%),linear-gradient(135deg,#5a4354,#3d2d37);border:1px solid #ffffff24;border-radius:22px;box-shadow:0 12px 28px #54354633;height:60px;padding:.38rem;width:60px}html[data-theme=sunset] .nav-name{font-family:Fraunces,serif;font-size:1.7rem;font-weight:500;letter-spacing:-.02em}html[data-theme=sunset] .nav-links{gap:.55rem}html[data-theme=sunset] .nav-links a{border-radius:999px;color:var(--secondary-text-color);font-size:.87rem;font-weight:700;letter-spacing:.08em;margin-left:0;padding:.6rem .95rem;text-transform:uppercase;transition:transform .2s ease,color .2s ease,background .2s ease,box-shadow .2s ease}html[data-theme=sunset] .nav-links a:hover{background:#ffffff80;box-shadow:0 12px 24px #7c4f691a;color:var(--primary-text-color);transform:translateY(-1px)}html[data-theme=sunset] .hero{align-items:stretch;min-height:90vh;padding:3rem 0 2rem}html[data-theme=sunset] .hero:before{background:radial-gradient(circle,#fff4d7eb 0,#f3b36be0 45%,#f3b36b14 72%,#0000 73%);border-radius:50%;filter:blur(0);height:24rem;left:auto;opacity:.96;right:7%;top:10%;width:24rem}html[data-theme=sunset] .hero:after{background:linear-gradient(180deg,#ffc49f00,#ffc49f33),linear-gradient(180deg,#fff0,#7c4f6914);border-radius:50% 50% 0 0;bottom:-10%;filter:blur(0);height:24rem;left:-15%;right:auto;width:130%}html[data-theme=sunset] .hero-content{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(140deg,#ffffff8f,#ffffff1f),var(--hero-shell-bg);border:1px solid #7c4f691a;border-radius:42px;box-shadow:0 28px 80px #7e4f6724,inset 0 1px 0 #ffffff75;margin:auto;overflow:hidden;padding:3.5rem 3rem 3rem;text-align:left;width:min(94%,1120px)}html[data-theme=sunset] .hero-content:before{color:var(--accent-magenta);content:"Sunset Mode";font-size:.8rem;font-weight:700;letter-spacing:.16em;margin-bottom:1rem}html[data-theme=sunset] .hero-content:after{background:radial-gradient(circle,#ffffff6b,#0000 48%),radial-gradient(circle at 40% 35%,#f3b36b8f,#d86f532e 54%,#0000 72%);border-radius:50%;bottom:-7rem;content:"";height:26rem;opacity:.95;pointer-events:none;position:absolute;right:-6rem;width:26rem}html[data-theme=sunset] .hero-content h1{font-family:Fraunces,serif;font-size:clamp(4.1rem,9vw,7.2rem);font-weight:500;letter-spacing:-.045em;line-height:.88;margin-bottom:1.2rem;max-width:8ch;position:relative;z-index:1}html[data-theme=sunset] .hero-content p{color:var(--secondary-text-color);font-size:1rem;line-height:1.95;margin:0;max-width:670px;position:relative;z-index:1}html[data-theme=sunset] .glitch{color:var(--primary-text-color)}html[data-theme=sunset] .glitch:before{color:#f3b36be6;opacity:.5;transform:translate(-5px,2px)}html[data-theme=sunset] .glitch:after{color:#7c4f69b3;opacity:.42;transform:translate(5px,-2px)}html[data-theme=sunset] .particle{animation:sunset-rise 10s ease-in infinite;background:#f3b36b59;border-radius:999px;box-shadow:0 0 10px #f3b36b2e;transform:translateZ(0);will-change:transform,opacity}html[data-theme=sunset] .mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}html[data-theme=sunset] .trail-particle{animation:sunset-trail-fade .38s forwards;border-radius:999px;box-shadow:0 0 10px currentColor;height:14px;opacity:.38;position:absolute;transform:translate(-50%,-50%);transform:translate(-50%,-50%) translateZ(0);width:14px;will-change:transform,opacity}html[data-theme=sunset] .contact-container,html[data-theme=sunset] .featured-project-section,html[data-theme=sunset] .skills-container,html[data-theme=sunset] .timeline-container{width:min(94%,1220px)}html[data-theme=sunset] .featured-project-shell{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(160deg,#ffffff8a,#ffffff2e),linear-gradient(180deg,#ffe9ddbd,#fff5edad);border:1px solid #7c4f691a;border-radius:38px;box-shadow:0 26px 80px #7d50651f,inset 0 1px 0 #fff9;overflow:hidden;padding:2.7rem;position:relative}html[data-theme=sunset] .featured-project-shell:before{background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan),var(--accent-gold));content:"";height:10px;inset:0 0 auto 0;opacity:.9;position:absolute}html[data-theme=sunset] .featured-project-shell:after{background:radial-gradient(circle,#f3b36b4d,#0000 62%);border-radius:50%;content:"";height:18rem;pointer-events:none;position:absolute;right:-5rem;top:-4rem;width:18rem}html[data-theme=sunset] .featured-project-kicker,html[data-theme=sunset] .project-media-kicker,html[data-theme=sunset] .system-detail-kicker,html[data-theme=sunset] .theme-lab-kicker,html[data-theme=sunset] .theme-lab-trigger-label{color:var(--accent-magenta);font-size:.76rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}html[data-theme=sunset] .about-text h2,html[data-theme=sunset] .contact-tile h2,html[data-theme=sunset] .featured-project-header h2,html[data-theme=sunset] .project-details h3,html[data-theme=sunset] .project-header h1,html[data-theme=sunset] .project-media-placeholder h2,html[data-theme=sunset] .skill-category h3,html[data-theme=sunset] .skills-title,html[data-theme=sunset] .system-detail-topbar h3,html[data-theme=sunset] .theme-lab-drawer h3,html[data-theme=sunset] .theme-lab-trigger strong,html[data-theme=sunset] .timeline-title{font-family:Fraunces,serif;font-weight:500;letter-spacing:-.03em}html[data-theme=sunset] .featured-project-header h2{font-size:clamp(3.1rem,6vw,5.2rem);line-height:.92;margin:.55rem 0 .8rem;max-width:12ch}html[data-theme=sunset] .about-text p,html[data-theme=sunset] .contact-item,html[data-theme=sunset] .featured-project-header p,html[data-theme=sunset] .featured-project-summary p,html[data-theme=sunset] .project-details p,html[data-theme=sunset] .project-media-placeholder p,html[data-theme=sunset] .system-detail-stack,html[data-theme=sunset] .system-detail-summary,html[data-theme=sunset] .system-log-line,html[data-theme=sunset] .theme-lab-note,html[data-theme=sunset] .timeline-project-preview{color:var(--secondary-text-color)}html[data-theme=sunset] .featured-project-summary{margin-bottom:1.4rem;max-width:820px}html[data-theme=sunset] .system-selector{gap:.7rem;margin-bottom:1.4rem}html[data-theme=sunset] .system-selector-button{background:#ffffff6b;border:1px solid #7c4f691f;border-radius:999px;box-shadow:inset 0 1px 0 #ffffff70;color:var(--secondary-text-color);font-weight:700;padding:.78rem 1.15rem;transition:transform .22s ease,box-shadow .22s ease,background .22s ease,color .22s ease}html[data-theme=sunset] .system-selector-button.active,html[data-theme=sunset] .system-selector-button:hover{background:linear-gradient(135deg,var(--accent-magenta),var(--accent-cyan));box-shadow:0 14px 28px #7c4f692e;color:#fff9f5;transform:translateY(-2px)}html[data-theme=sunset] .about-text,html[data-theme=sunset] .contact-tile,html[data-theme=sunset] .project-details,html[data-theme=sunset] .project-media-placeholder,html[data-theme=sunset] .skill-category,html[data-theme=sunset] .system-detail-card,html[data-theme=sunset] .terminal-container,html[data-theme=sunset] .theme-lab-drawer,html[data-theme=sunset] .theme-lab-trigger{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(180deg,#ffffff94,#ffffff2e),var(--paper-strong);border:1px solid #7c4f691f;border-radius:32px;box-shadow:0 24px 60px #7f4d5e1a,inset 0 1px 0 #ffffff85}html[data-theme=sunset] .system-detail-card{overflow:hidden;padding:2rem;position:relative}html[data-theme=sunset] .system-detail-card:before{background:linear-gradient(180deg,#0000,#d86f5314);content:"";height:42%;inset:auto 0 0 0;pointer-events:none;position:absolute}html[data-theme=sunset] .system-detail-topbar h3{font-size:clamp(2rem,4vw,3.1rem);line-height:.96;position:relative;z-index:1}html[data-theme=sunset] .system-detail-stack,html[data-theme=sunset] .system-detail-summary,html[data-theme=sunset] .system-log{position:relative;z-index:1}html[data-theme=sunset] .system-detail-stack,html[data-theme=sunset] .system-detail-summary{line-height:1.85}html[data-theme=sunset] .system-detail-stack strong{color:var(--primary-text-color)}html[data-theme=sunset] .system-log{grid-gap:.7rem;display:grid;gap:.7rem}html[data-theme=sunset] .system-log-line{gap:.75rem;line-height:1.75}html[data-theme=sunset] .system-log-prompt{color:var(--accent-cyan);font-weight:800}html[data-theme=sunset] .featured-project-actions{gap:.85rem;margin-top:1.6rem}html[data-theme=sunset] .featured-project-button,html[data-theme=sunset] .project-live-link,html[data-theme=sunset] .theme-lab-button,html[data-theme=sunset] .timeline-read-more{border-radius:999px;transition:transform .22s ease,box-shadow .22s ease,background .22s ease,color .22s ease}html[data-theme=sunset] .featured-project-button,html[data-theme=sunset] .project-live-link{font-weight:700;padding:.92rem 1.3rem}html[data-theme=sunset] .featured-project-button.primary,html[data-theme=sunset] .project-live-link,html[data-theme=sunset] .theme-lab-button.primary{background:linear-gradient(135deg,var(--accent-magenta),var(--accent-cyan));border:1px solid #0000;box-shadow:0 16px 30px #7c4f692e;color:#fff9f4}html[data-theme=sunset] .featured-project-button.secondary{background:#ffffff6b;border:1px solid #7c4f691f;color:var(--primary-text-color)}html[data-theme=sunset] .featured-project-button:hover,html[data-theme=sunset] .project-live-link:hover,html[data-theme=sunset] .theme-lab-button:hover{box-shadow:0 18px 34px #7c4f6933;transform:translateY(-3px)}html[data-theme=sunset] .timeline-container{margin:4.4rem auto}html[data-theme=sunset] .about-text h2,html[data-theme=sunset] .skills-title,html[data-theme=sunset] .timeline-title{font-size:clamp(3rem,5vw,4.6rem);margin-bottom:2.6rem;text-align:center}html[data-theme=sunset] .timeline-line{background:linear-gradient(180deg,#7c4f691f,#d86f535c,#f3b36b9e,#7c4f691f);width:3px}html[data-theme=sunset] .timeline-dot{background:radial-gradient(circle,#fff7ea 10%,var(--accent-gold) 58%,var(--accent-cyan) 100%);border:none;box-shadow:0 0 0 6px #ffffff61,0 0 30px #f3b36b75;height:20px;top:1.15rem;width:20px}html[data-theme=sunset] .timeline-content{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(180deg,#fff9,#ffffff2e),#fffaf5a8;border:1px solid #7c4f691f;border-radius:28px;box-shadow:0 24px 56px #7c4f6914,inset 0 1px 0 #ffffff85;overflow:hidden}html[data-theme=sunset] .timeline-content:before{background:linear-gradient(160deg,#f3b36b24,#0000 45%,#7c4f690f);content:"";inset:0;opacity:1;position:absolute}html[data-theme=sunset] .timeline-content:after{background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan),var(--accent-gold));content:"";height:6px;inset:auto 0 0 0;opacity:.75;position:absolute}html[data-theme=sunset] .timeline-date,html[data-theme=sunset] .timeline-project-preview,html[data-theme=sunset] .timeline-project-title{position:relative;z-index:1}html[data-theme=sunset] .timeline-date{color:var(--accent-magenta);font-size:.78rem;font-weight:800;letter-spacing:.14em;margin-bottom:.75rem;text-transform:uppercase}html[data-theme=sunset] .timeline-project-title{font-family:Fraunces,serif;font-size:2rem;font-weight:500;line-height:.98;margin-bottom:.75rem}html[data-theme=sunset] .timeline-project-preview{font-size:.93rem;line-height:1.82}html[data-theme=sunset] .timeline-read-more{color:var(--accent-cyan);font-weight:700;margin-top:.9rem}html[data-theme=sunset] .timeline-item:hover .timeline-content{border-color:#d86f532e;box-shadow:0 30px 60px #7c4f6924;transform:translateY(-6px) scale(1.01)}html[data-theme=sunset] .about-content{align-items:center;gap:2.6rem}html[data-theme=sunset] .about-text{padding:2.25rem}html[data-theme=sunset] .about-text h2{margin-bottom:1.2rem;text-align:left}html[data-theme=sunset] .about-text p{line-height:1.9;margin-bottom:1rem}html[data-theme=sunset] .about-image{max-width:360px;position:relative}html[data-theme=sunset] .about-image:before{background:linear-gradient(145deg,#f3b36b59,#d86f532e 55%,#7c4f6933);border-radius:44px;content:"";inset:-18px -18px 24px 24px;position:absolute;z-index:0}html[data-theme=sunset] .about-image:after{background:radial-gradient(circle,#fff6,#f3b36b2e 60%,#0000 68%);border-radius:50%;content:"";height:120px;inset:auto -28px -22px auto;position:absolute;width:120px;z-index:0}html[data-theme=sunset] .about-image img{background:#ffffff57;border:1px solid #ffffff57;border-radius:36px 36px 72px 36px;box-shadow:0 24px 56px #7c4f6929;padding:.65rem;position:relative;width:100%;z-index:1}html[data-theme=sunset] .about-image:hover img{transform:translateY(-5px) rotate(-1.2deg)}html[data-theme=sunset] .skills-container{margin:4.4rem auto}html[data-theme=sunset] .skills-grid{gap:1.45rem}html[data-theme=sunset] .skill-category{overflow:hidden;padding:1.8rem;position:relative}html[data-theme=sunset] .skill-category:before{background:linear-gradient(90deg,var(--accent-magenta),var(--accent-cyan),var(--accent-gold));content:"";height:10px;inset:0 0 auto 0;opacity:.8;position:absolute}html[data-theme=sunset] .skill-category:after{background:radial-gradient(circle,#f3b36b38,#0000 68%);border-radius:50%;bottom:-2.5rem;content:"";height:8rem;pointer-events:none;position:absolute;right:-2.5rem;width:8rem}html[data-theme=sunset] .skill-category .border-svg{display:none}html[data-theme=sunset] .skill-category h3{font-size:2rem;margin-bottom:1rem;position:relative;z-index:1}html[data-theme=sunset] .skill-category ul{display:flex;flex-wrap:wrap;gap:.65rem;position:relative;z-index:1}html[data-theme=sunset] .skill-category li{background:#ffffff70;border:1px solid #7c4f691a;border-radius:999px;color:var(--secondary-text-color);font-size:.9rem;padding:.6rem .9rem}html[data-theme=sunset] .skill-category:hover{box-shadow:0 30px 64px #7c4f6924;transform:translateY(-6px)}html[data-theme=sunset] .skill-category:nth-child(2):hover{transform:translateY(-6px) rotate(-.4deg)}html[data-theme=sunset] .skill-category:nth-child(3):hover{transform:translateY(-6px) rotate(.4deg)}html[data-theme=sunset] .terminal-container{background:linear-gradient(180deg,#ffffff94,#ffffff24),#fff8f2b3;border-radius:34px;max-width:980px}html[data-theme=sunset] .terminal-header{background:linear-gradient(90deg,#ffffff6b,#ffe8de80);border-bottom:1px solid #7c4f691a;padding:1rem}html[data-theme=sunset] .terminal-header-dot.red{background:#e28463}html[data-theme=sunset] .terminal-header-dot.yellow{background:#f3b36b}html[data-theme=sunset] .terminal-header-dot.green{background:#7c4f69}html[data-theme=sunset] .terminal-body{background:linear-gradient(180deg,#ffffff29,#fff8f21a)}html[data-theme=sunset] .contact-item a,html[data-theme=sunset] .prompt-text,html[data-theme=sunset] .terminal-line.link a{color:var(--accent-cyan)}html[data-theme=sunset] .contact-item a:hover,html[data-theme=sunset] .terminal-line.link a:hover{color:var(--accent-magenta)}html[data-theme=sunset] .project-page-container{padding:2.4rem 0 4.2rem;width:min(94%,1140px)}html[data-theme=sunset] .project-header{border-bottom:1px solid #7c4f691a;margin-bottom:2.1rem;padding-bottom:2rem}html[data-theme=sunset] .project-header h1{font-size:clamp(3.2rem,7vw,5.6rem);line-height:.9;max-width:12ch}html[data-theme=sunset] .project-header span{color:var(--accent-magenta);font-size:.8rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase}html[data-theme=sunset] .back-link{color:var(--accent-cyan);font-weight:700}html[data-theme=sunset] .project-body.side-by-side{gap:2rem}html[data-theme=sunset] .main-image-container{max-width:760px;width:100%}html[data-theme=sunset] .main-image,html[data-theme=sunset] .main-video,html[data-theme=sunset] .thumbnail-image{background:#ffffff61}html[data-theme=sunset] .main-image,html[data-theme=sunset] .main-video{border:1px solid #7c4f691f;border-radius:34px;box-shadow:0 26px 60px #7c4f6924}html[data-theme=sunset] .main-image-container:before{background:linear-gradient(145deg,#f3b36b3d,#7c4f692e);border-radius:36px;content:"";inset:auto -20px -18px 18px;position:absolute;z-index:-1}html[data-theme=sunset] .main-image-container:after{background:radial-gradient(circle,#ffffff5c,#f3b36b33 62%,#0000 70%);border-radius:50%;content:"";height:84px;inset:-12px 36px auto auto;pointer-events:none;position:absolute;width:84px;z-index:1}html[data-theme=sunset] .main-image-container:hover .main-image,html[data-theme=sunset] .main-image-container:hover .main-video{transform:translateY(-4px)}html[data-theme=sunset] .thumbnail-container{gap:.75rem}html[data-theme=sunset] .thumbnail-image{border:1px solid #7c4f691f;border-radius:18px;padding:.2rem}html[data-theme=sunset] .thumbnail-image:hover{border-color:#d86f5357}html[data-theme=sunset] .thumbnail-image.active{border-color:#7c4f694d;box-shadow:0 12px 26px #7c4f691f}html[data-theme=sunset] .project-details,html[data-theme=sunset] .project-media-placeholder{padding:2rem}html[data-theme=sunset] .project-media-placeholder{background:radial-gradient(circle at top right,#f3b36b42,#0000 28%),linear-gradient(180deg,#ffffff8f,#fff4ed38),#fff9f4b8;min-height:420px}html[data-theme=sunset] .project-details h3,html[data-theme=sunset] .project-media-placeholder h2{font-size:2.3rem;line-height:.98}html[data-theme=sunset] .project-details p,html[data-theme=sunset] .project-media-placeholder p{line-height:1.92}html[data-theme=sunset] .footer{background:#0000;border-top:1px solid #7c4f6914;color:var(--secondary-text-color)}html[data-theme=sunset] .theme-lab-trigger{min-width:176px;padding:.9rem 1rem}html[data-theme=sunset] .theme-lab-trigger strong{font-size:1.45rem;margin-top:.38rem}html[data-theme=sunset] .theme-lab-drawer{padding:1.35rem;width:min(380px,calc(100vw - 2rem))}html[data-theme=sunset] .theme-lab-drawer h3{font-size:2rem;line-height:.96;margin:.45rem 0 0}html[data-theme=sunset] .theme-lab-note{line-height:1.8;margin-top:.95rem}html[data-theme=sunset] .theme-lab-close:hover{color:var(--accent-magenta)}@keyframes sunset-rise{0%{opacity:0;transform:translateY(110vh) scale(.9)}18%{opacity:.55}to{opacity:0;transform:translateY(-12vh) scale(1.08)}}@keyframes sunset-trail-fade{0%{opacity:.5;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.8)}}@media (max-width:768px){html[data-theme=sunset] .navbar{padding-top:.8rem}html[data-theme=sunset] .navbar-inner{padding:.85rem .95rem;position:relative;width:95%}html[data-theme=sunset] .nav-links{display:none}html[data-theme=sunset] .nav-links.active{background:#fff8f2f0;border:1px solid #7c4f691a;border-radius:24px;box-shadow:0 22px 44px #7c4f691f;display:flex;flex-direction:column;gap:.4rem;left:0;padding:.7rem;position:absolute;right:0;top:calc(100% + .7rem)}html[data-theme=sunset] .nav-links.active a{background:#ffffff61;padding:.9rem 1rem;text-align:center;width:100%}html[data-theme=sunset] .hamburger-menu{background:#0000;border:none;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:30px}html[data-theme=sunset] .hamburger-bar{background:var(--primary-text-color);border-radius:999px;height:2px;transition:all .3s ease-in-out;width:100%}html[data-theme=sunset] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=sunset] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=sunset] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=sunset] .hero{min-height:auto;padding:2rem 0 2.2rem}html[data-theme=sunset] .hero:before{height:14rem;right:-1rem;top:4rem;width:14rem}html[data-theme=sunset] .hero:after{bottom:-7rem;height:16rem}html[data-theme=sunset] .hero-content{border-radius:32px;padding:2.2rem 1.35rem 2rem;width:95%}html[data-theme=sunset] .hero-content h1{font-size:clamp(3.2rem,15vw,4.9rem);max-width:none}html[data-theme=sunset] .hero-content p{font-size:.97rem;max-width:none}html[data-theme=sunset] .about-text,html[data-theme=sunset] .contact-tile,html[data-theme=sunset] .featured-project-shell,html[data-theme=sunset] .project-details,html[data-theme=sunset] .project-media-placeholder,html[data-theme=sunset] .skill-category,html[data-theme=sunset] .system-detail-card,html[data-theme=sunset] .terminal-container,html[data-theme=sunset] .theme-lab-drawer,html[data-theme=sunset] .theme-lab-trigger{border-radius:28px;padding:1.35rem}html[data-theme=sunset] .about-text h2,html[data-theme=sunset] .featured-project-header h2,html[data-theme=sunset] .skills-title,html[data-theme=sunset] .timeline-title{font-size:clamp(2.35rem,12vw,3.3rem)}html[data-theme=sunset] .system-selector-button{text-align:left;width:100%}html[data-theme=sunset] .timeline-line{left:18px;transform:translateX(0)}html[data-theme=sunset] .timeline-item,html[data-theme=sunset] .timeline-item:nth-child(2n){left:0;padding-left:3.5rem;padding-right:0;text-align:left;width:100%}html[data-theme=sunset] .timeline-dot,html[data-theme=sunset] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=sunset] .timeline-item:nth-child(odd) .timeline-dot{left:8px;right:auto}html[data-theme=sunset] .about-content{gap:1.7rem;grid-template-columns:1fr}html[data-theme=sunset] .about-image{max-width:270px;order:1}html[data-theme=sunset] .about-text{order:2}html[data-theme=sunset] .project-body.side-by-side{flex-direction:column}html[data-theme=sunset] .project-body.side-by-side .project-details,html[data-theme=sunset] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=sunset] .featured-project-actions{flex-direction:column}html[data-theme=sunset] .theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}html[data-theme=sunset] .theme-lab-drawer,html[data-theme=sunset] .theme-lab-trigger{width:100%}}@media (min-width:769px){html[data-theme=sunset] .hamburger-menu{display:none}}html[data-theme=swiss]{--bg-color:#f4f0e7;--paper-color:#fbf8f1;--paper-strong:#fff;--primary-text-color:#141414;--secondary-text-color:#5e5a56;--accent-cyan:#0d4fd8;--accent-magenta:#d81f26;--accent-gold:#f0c24b;--border-color:#1414141f;--card-bg:#fbf8f1;--accent-cyan-glow:#0d4fd833;--shadow-soft:none;--logo-badge-bg:#202020;--logo-badge-border:#1414142e;--nav-shell-bg:#fbf8f1f0;--nav-wash:linear-gradient(180deg,#f4f0e7f5,#f4f0e7d1 72%,#0000);--hero-shell-bg:#fbf8f1;--button-inverse-text:#faf7f0;--ghost-pill-bg:#14141408;--ghost-button-bg:#14141408;--surface-strong-bg:#ffffffe6;--surface-soft-bg:#1414140a;--inner-highlight:#ffffff52}html[data-theme=swiss] body{background:linear-gradient(90deg,#0000,#0000 calc(12% - 1px),#14141414 calc(12% - 1px),#14141414 12%,#0000 0,#0000 calc(56% - 1px),#14141414 calc(56% - 1px),#14141414 56%,#0000 0,#0000 calc(88% - 1px),#14141414 calc(88% - 1px),#14141414 88%,#0000 0),linear-gradient(180deg,#d81f261f 0 12%,#0000 12% 100%),linear-gradient(180deg,#f7f3eb,#f1ece4);color:var(--primary-text-color);font-family:Space Grotesk,sans-serif}html[data-theme=swiss] .navbar{background:var(--nav-wash);padding:.9rem 0 0}html[data-theme=swiss] .navbar-inner{-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border:none;border-bottom:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;padding:1rem 0;width:min(94%,1260px)}html[data-theme=swiss] .logo-title{gap:1rem}html[data-theme=swiss] .nav-logo{background:var(--logo-badge-bg);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;height:62px;padding:.35rem;width:62px}html[data-theme=swiss] .nav-name{font-family:Space Grotesk,sans-serif;font-size:1.45rem;font-weight:700;letter-spacing:-.03em;text-transform:uppercase}html[data-theme=swiss] .nav-links{gap:.45rem}html[data-theme=swiss] .nav-links a{color:var(--primary-text-color);font-size:.82rem;font-weight:700;letter-spacing:.08em;margin-left:0;padding:.45rem .6rem;position:relative;text-transform:uppercase}html[data-theme=swiss] .nav-links a:after{background:var(--accent-magenta);bottom:.25rem;content:"";height:2px;left:.6rem;position:absolute;right:.6rem;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}html[data-theme=swiss] .nav-links a:hover{color:var(--accent-magenta);transform:none}html[data-theme=swiss] .nav-links a:hover:after{transform:scaleX(1)}html[data-theme=swiss] .hero{min-height:88vh;padding:2rem 0 2.5rem;text-align:left}html[data-theme=swiss] .hero:before{background:linear-gradient(180deg,#d81f26f2,#d81f26d1);border-radius:0;filter:none;height:100%;left:0;top:0;width:34vw}html[data-theme=swiss] .hero:after{background:linear-gradient(135deg,#0000 0 48%,#0d4fd8e6 48% 52%,#0000 52% 100%),linear-gradient(45deg,#0000 0 48%,#0d4fd8e6 48% 52%,#0000 52% 100%);border-radius:0;bottom:12%;filter:none;height:22vw;opacity:.18;right:6%;width:22vw}html[data-theme=swiss] .hero-content{grid-gap:2rem;align-items:start;background:#0000;border:none;border-radius:0;box-shadow:none;display:grid;gap:2rem;grid-template-columns:minmax(0,.78fr) minmax(280px,.22fr);margin:auto;min-height:70vh;padding:5rem 0 3rem;width:min(94%,1260px)}html[data-theme=swiss] .hero-content:before{color:var(--primary-text-color);content:"ENGINEERING / SYSTEMS / INTERFACES";display:block;font-size:.8rem;font-weight:700;grid-column:1/-1;letter-spacing:.18em;margin-left:12%;text-transform:uppercase}html[data-theme=swiss] .hero-content:after{color:#fffc;content:"2026";font-size:.82rem;font-weight:700;left:2.5rem;letter-spacing:.18em;position:absolute;top:5.2rem;transform:rotate(180deg);writing-mode:vertical-rl}html[data-theme=swiss] .hero-content h1{font-family:Space Grotesk,sans-serif;font-size:clamp(4.2rem,9vw,8rem);font-weight:700;grid-column:1;letter-spacing:-.07em;line-height:.9;margin-bottom:0;margin-left:12%;max-width:8ch;text-transform:uppercase}html[data-theme=swiss] .hero-content p{align-self:end;color:var(--secondary-text-color);font-family:IBM Plex Mono,monospace;font-size:.9rem;grid-column:2;line-height:1.9;margin:0 0 1.3rem auto;max-width:320px}html[data-theme=swiss] .glitch{color:var(--primary-text-color)}html[data-theme=swiss] .glitch:after,html[data-theme=swiss] .glitch:before{opacity:1}html[data-theme=swiss] .glitch:before{color:var(--accent-cyan);transform:translate(-6px)}html[data-theme=swiss] .glitch:after{color:var(--accent-magenta);transform:translate(6px)}html[data-theme=swiss] .particles-bg{z-index:-1}html[data-theme=swiss] .particle{animation:swiss-rise 10s linear infinite;background:var(--primary-text-color);border-radius:0;opacity:.08}html[data-theme=swiss] .mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}html[data-theme=swiss] .trail-particle{animation:swiss-trail-fade .35s forwards;border-radius:0;height:2px;opacity:.8;position:absolute;transform:translate(-50%,-50%);width:16px}html[data-theme=swiss] .contact-container,html[data-theme=swiss] .featured-project-section,html[data-theme=swiss] .skills-container,html[data-theme=swiss] .timeline-container{width:min(94%,1260px)}html[data-theme=swiss] .featured-project-shell{grid-gap:1.2rem 2.4rem;align-items:start;background:#0000;border:none;border-bottom:2px solid var(--primary-text-color);border-radius:0;border-top:4px solid var(--primary-text-color);box-shadow:none;display:grid;gap:1.2rem 2.4rem;grid-template-columns:minmax(0,.62fr) minmax(0,.38fr);padding:2rem 0 2.5rem;position:relative}html[data-theme=swiss] .featured-project-shell:before{background:var(--accent-magenta);content:"";height:14px;left:12%;position:absolute;top:0;width:18%}html[data-theme=swiss] .featured-project-shell:after{background:var(--accent-cyan);bottom:0;content:"";height:14px;position:absolute;right:0;width:24%}html[data-theme=swiss] .featured-project-header{grid-column:1/-1;margin:0;padding-bottom:.6rem;padding-left:12%}html[data-theme=swiss] .featured-project-actions,html[data-theme=swiss] .featured-project-summary{grid-column:2;padding-left:0}html[data-theme=swiss] .system-selector{grid-column:1;grid-row:2;margin-left:12%;max-width:40rem}html[data-theme=swiss] .featured-project-summary{grid-row:2}html[data-theme=swiss] .featured-project-actions{grid-column:1/-1;grid-row:4}html[data-theme=swiss] .system-detail-card{grid-column:1/-1;grid-row:3}html[data-theme=swiss] .featured-project-kicker,html[data-theme=swiss] .project-media-kicker,html[data-theme=swiss] .system-detail-kicker,html[data-theme=swiss] .theme-lab-trigger-label{color:var(--primary-text-color);display:inline-block;font-family:IBM Plex Mono,monospace;font-size:.76rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase}html[data-theme=swiss] .about-text h2,html[data-theme=swiss] .contact-tile h2,html[data-theme=swiss] .featured-project-header h2,html[data-theme=swiss] .project-details h3,html[data-theme=swiss] .project-header h1,html[data-theme=swiss] .project-media-placeholder h2,html[data-theme=swiss] .skill-category h3,html[data-theme=swiss] .skills-title,html[data-theme=swiss] .system-detail-topbar h3,html[data-theme=swiss] .theme-lab-drawer h3,html[data-theme=swiss] .theme-lab-trigger strong,html[data-theme=swiss] .timeline-title{font-family:Space Grotesk,sans-serif;font-weight:700;letter-spacing:-.05em;text-transform:uppercase}html[data-theme=swiss] .featured-project-header h2{font-size:clamp(3.2rem,5.7vw,5.6rem);line-height:.9;margin:.7rem 0 .9rem;max-width:11ch}html[data-theme=swiss] .about-text p,html[data-theme=swiss] .contact-item,html[data-theme=swiss] .featured-project-header p,html[data-theme=swiss] .featured-project-summary p,html[data-theme=swiss] .project-details p,html[data-theme=swiss] .project-media-placeholder p,html[data-theme=swiss] .system-detail-stack,html[data-theme=swiss] .system-detail-summary,html[data-theme=swiss] .system-log-line,html[data-theme=swiss] .theme-lab-note,html[data-theme=swiss] .timeline-project-preview{color:var(--secondary-text-color)}html[data-theme=swiss] .featured-project-header p,html[data-theme=swiss] .featured-project-summary p{font-family:IBM Plex Mono,monospace;line-height:1.85}html[data-theme=swiss] .featured-project-summary{border-top:2px solid var(--primary-text-color);margin:0;max-width:28rem;padding:1rem 0 0}html[data-theme=swiss] .system-selector{grid-gap:0;align-self:start;border-left:2px solid var(--primary-text-color);border-top:2px solid var(--primary-text-color);display:grid;gap:0;grid-template-columns:repeat(3,minmax(0,1fr))}html[data-theme=swiss] .system-selector-button{background:#0000;border:none;border-bottom:2px solid var(--primary-text-color);border-radius:0;border-right:2px solid var(--primary-text-color);color:var(--primary-text-color);font-weight:700;letter-spacing:.05em;padding:.9rem 1rem;text-transform:uppercase;transition:background .2s ease,color .2s ease}html[data-theme=swiss] .system-selector-button.active,html[data-theme=swiss] .system-selector-button:hover{background:var(--accent-magenta);color:#fff;transform:none}html[data-theme=swiss] .system-detail-card{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;margin-top:.35rem;min-height:100%;padding:1.6rem 1.6rem 1.6rem 4.8rem;position:relative}html[data-theme=swiss] .system-detail-card:before{background:var(--accent-cyan);bottom:0;content:"";left:0;position:absolute;top:0;width:22px}html[data-theme=swiss] .system-detail-card:after{background:var(--accent-magenta);bottom:0;content:"";left:22px;position:absolute;top:0;width:22px}html[data-theme=swiss] .system-detail-topbar h3{font-size:clamp(1.9rem,3.6vw,3rem);line-height:.94}html[data-theme=swiss] .system-detail-stack,html[data-theme=swiss] .system-detail-summary,html[data-theme=swiss] .system-log-line{font-family:IBM Plex Mono,monospace;line-height:1.8}html[data-theme=swiss] .system-detail-stack strong{color:var(--primary-text-color)}html[data-theme=swiss] .system-log{grid-gap:.5rem;display:grid;gap:.5rem}html[data-theme=swiss] .system-log-prompt{color:var(--accent-magenta);font-weight:700}html[data-theme=swiss] .featured-project-actions{align-self:end;display:flex;gap:.8rem;justify-content:flex-start;margin-top:.1rem}html[data-theme=swiss] .featured-project-button,html[data-theme=swiss] .project-live-link,html[data-theme=swiss] .theme-lab-button,html[data-theme=swiss] .timeline-read-more{border-radius:0;transition:background .2s ease,color .2s ease,transform .2s ease}html[data-theme=swiss] .featured-project-button,html[data-theme=swiss] .project-live-link{font-family:IBM Plex Mono,monospace;font-weight:600;letter-spacing:.08em;padding:.95rem 1.15rem;text-transform:uppercase}html[data-theme=swiss] .featured-project-button.primary,html[data-theme=swiss] .project-live-link,html[data-theme=swiss] .theme-lab-button.primary{background:var(--primary-text-color);border:2px solid var(--primary-text-color);color:#fff}html[data-theme=swiss] .featured-project-button.secondary{background:#0000;border:2px solid var(--primary-text-color);color:var(--primary-text-color)}html[data-theme=swiss] .featured-project-button:hover,html[data-theme=swiss] .project-live-link:hover,html[data-theme=swiss] .theme-lab-button:hover{transform:translate(4px,-4px)}html[data-theme=swiss] .featured-project-button.secondary:hover{background:var(--accent-cyan);border-color:var(--accent-cyan);color:#fff}html[data-theme=swiss] .timeline-container{margin:4rem auto}html[data-theme=swiss] .skills-title,html[data-theme=swiss] .timeline-title{font-size:clamp(3rem,5vw,4.9rem);margin-bottom:2.2rem;padding-left:12%;text-align:left}html[data-theme=swiss] .about-text h2{font-size:clamp(2.8rem,4.7vw,4.2rem);margin-bottom:1.2rem;text-align:left}html[data-theme=swiss] .timeline{padding-top:0}html[data-theme=swiss] .timeline-line{background:var(--primary-text-color);left:12%;transform:none;width:4px}html[data-theme=swiss] .timeline-item,html[data-theme=swiss] .timeline-item:nth-child(2n),html[data-theme=swiss] .timeline-item:nth-child(odd){left:0;margin-bottom:1.2rem;padding:0 0 0 18%;text-align:left;width:auto}html[data-theme=swiss] .timeline-dot,html[data-theme=swiss] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=swiss] .timeline-item:nth-child(odd) .timeline-dot{background:var(--accent-gold);border:3px solid var(--primary-text-color);border-radius:0;height:18px;left:calc(12% - 8px);right:auto;top:1.1rem;transform:rotate(45deg);width:18px}html[data-theme=swiss] .timeline-item:hover .timeline-dot{background:var(--accent-magenta)}html[data-theme=swiss] .timeline-content{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;overflow:hidden;padding:1.5rem 1.5rem 1.5rem 7rem;position:relative}html[data-theme=swiss] .timeline-content:before{background:var(--accent-magenta);content:"";inset:0 auto 0 0;opacity:1;position:absolute;width:34px}html[data-theme=swiss] .timeline-content:after{background:var(--accent-cyan);content:"";inset:0 auto 0 34px;position:absolute;width:18px}html[data-theme=swiss] .timeline-item:hover .timeline-content{border-color:var(--primary-text-color);box-shadow:none;transform:translateX(8px)}html[data-theme=swiss] .timeline-date,html[data-theme=swiss] .timeline-project-preview,html[data-theme=swiss] .timeline-project-title{position:relative;z-index:1}html[data-theme=swiss] .timeline-date{color:var(--accent-magenta);font-family:IBM Plex Mono,monospace;font-size:.78rem;font-weight:600;letter-spacing:.16em;margin-bottom:.65rem;text-transform:uppercase}html[data-theme=swiss] .timeline-project-title{font-family:Space Grotesk,sans-serif;font-size:1.95rem;font-weight:700;line-height:.95;margin-bottom:.7rem;text-transform:uppercase}html[data-theme=swiss] .timeline-project-preview{font-family:IBM Plex Mono,monospace;font-size:.88rem;line-height:1.75}html[data-theme=swiss] .timeline-read-more{color:var(--accent-cyan);display:inline-block;font-family:IBM Plex Mono,monospace;font-weight:600;margin-top:.9rem;text-transform:uppercase}html[data-theme=swiss] .about-container{padding:4rem 0}html[data-theme=swiss] .about-content{align-items:stretch;gap:2.2rem;grid-template-columns:minmax(260px,.28fr) minmax(0,.72fr);width:min(94%,1260px)}html[data-theme=swiss] .about-image{max-width:100%;order:1}html[data-theme=swiss] .about-image img{background:#0000;border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;filter:grayscale(100%) contrast(1.05);height:100%;object-fit:cover;padding:0;width:100%}html[data-theme=swiss] .about-image:hover img{filter:grayscale(0) contrast(1);transform:none}html[data-theme=swiss] .about-text{background:#0000;border:none;border-radius:0;border-top:4px solid var(--primary-text-color);box-shadow:none;order:2;padding:1.1rem 0 0 12%}html[data-theme=swiss] .about-text p{font-family:IBM Plex Mono,monospace;line-height:1.9;margin-bottom:1rem;max-width:72ch}html[data-theme=swiss] .skills-container{margin:4rem auto}html[data-theme=swiss] .skills-grid{border-left:2px solid var(--primary-text-color);border-top:2px solid var(--primary-text-color);gap:0;grid-template-columns:repeat(3,minmax(0,1fr))}html[data-theme=swiss] .skill-category{background:#0000;border-bottom:2px solid var(--primary-text-color);border-radius:0;border-right:2px solid var(--primary-text-color);box-shadow:none;min-height:100%;padding:1.5rem}html[data-theme=swiss] .skill-category:before{background:var(--accent-magenta);content:"";display:block;height:12px;margin-bottom:1rem;width:64px}html[data-theme=swiss] .skill-category:nth-child(2):before{background:var(--accent-cyan)}html[data-theme=swiss] .skill-category:nth-child(3):before{background:var(--accent-gold)}html[data-theme=swiss] .skill-category .border-svg{display:none}html[data-theme=swiss] .skill-category h3{font-size:1.8rem;margin-bottom:1rem}html[data-theme=swiss] .skill-category ul{grid-gap:.45rem;display:grid;gap:.45rem;grid-template-columns:1fr}html[data-theme=swiss] .skill-category li{background:#0000;border:none;border-bottom:1px solid #1414141f;border-radius:0;color:var(--secondary-text-color);font-family:IBM Plex Mono,monospace;font-size:.88rem;padding:.55rem 0}html[data-theme=swiss] .skill-category:hover{background:#d81f260d;transform:none}html[data-theme=swiss] .contact-tile,html[data-theme=swiss] .terminal-container{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none}html[data-theme=swiss] .terminal-header{background:#0000;border-bottom:2px solid var(--primary-text-color);padding:.85rem 1rem}html[data-theme=swiss] .terminal-header-dot.red{background:var(--accent-magenta)}html[data-theme=swiss] .terminal-header-dot.yellow{background:var(--accent-gold)}html[data-theme=swiss] .terminal-header-dot.green{background:var(--accent-cyan)}html[data-theme=swiss] .terminal-header span{color:var(--primary-text-color);font-family:IBM Plex Mono,monospace;font-size:.78rem;font-weight:600}html[data-theme=swiss] .contact-item,html[data-theme=swiss] .terminal-body,html[data-theme=swiss] .terminal-input,html[data-theme=swiss] .terminal-line{font-family:IBM Plex Mono,monospace}html[data-theme=swiss] .contact-item a,html[data-theme=swiss] .terminal-line.link a{color:var(--accent-cyan)}html[data-theme=swiss] .contact-item a:hover,html[data-theme=swiss] .terminal-line.link a:hover{color:var(--accent-magenta)}html[data-theme=swiss] .project-page-container{padding:2rem 0 4rem;width:min(94%,1260px)}html[data-theme=swiss] .project-header{align-items:flex-start;border-bottom:2px solid var(--primary-text-color);margin-bottom:2rem;padding:0 0 2rem;text-align:left}html[data-theme=swiss] .project-header h1{font-size:clamp(3.4rem,7vw,6rem);line-height:.9;max-width:12ch}html[data-theme=swiss] .project-header span{color:var(--accent-magenta);font-family:IBM Plex Mono,monospace;font-size:.8rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase}html[data-theme=swiss] .back-link{color:var(--accent-cyan);font-family:IBM Plex Mono,monospace;font-weight:600}html[data-theme=swiss] .project-body.side-by-side{gap:2rem}html[data-theme=swiss] .main-image-container{margin:0 auto 1rem;max-width:760px;width:100%}html[data-theme=swiss] .main-image,html[data-theme=swiss] .main-video{background:#0000;border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none}html[data-theme=swiss] .main-image-container:before{background:var(--accent-magenta);content:"";height:16px;inset:-16px auto auto -16px;position:absolute;width:96px}html[data-theme=swiss] .main-image-container:after{background:var(--accent-cyan);content:"";height:16px;inset:auto -16px -16px auto;position:absolute;width:96px}html[data-theme=swiss] .main-image-container:hover .main-image,html[data-theme=swiss] .main-image-container:hover .main-video{transform:translate(8px,-8px)}html[data-theme=swiss] .thumbnail-container{gap:.6rem}html[data-theme=swiss] .thumbnail-image{background:#0000;border:2px solid #0000;border-radius:0;padding:0}html[data-theme=swiss] .thumbnail-image:hover{border-color:var(--accent-cyan);transform:none}html[data-theme=swiss] .thumbnail-image.active{border-color:var(--accent-magenta);box-shadow:none}html[data-theme=swiss] .project-details,html[data-theme=swiss] .project-media-placeholder{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;padding:1.8rem}html[data-theme=swiss] .project-details h3,html[data-theme=swiss] .project-media-placeholder h2{font-size:2rem;line-height:.95}html[data-theme=swiss] .project-details p,html[data-theme=swiss] .project-media-placeholder p{font-family:IBM Plex Mono,monospace;line-height:1.85}html[data-theme=swiss] .footer{background:#0000;border-top:2px solid var(--primary-text-color);color:var(--secondary-text-color)}html[data-theme=swiss] .theme-lab-drawer,html[data-theme=swiss] .theme-lab-trigger{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none}html[data-theme=swiss] .theme-lab-trigger{min-width:172px;padding:.85rem .95rem}html[data-theme=swiss] .theme-lab-trigger strong{font-size:1.25rem;margin-top:.35rem}html[data-theme=swiss] .theme-lab-drawer{padding:1.2rem;width:min(360px,calc(100vw - 2rem))}html[data-theme=swiss] .theme-lab-drawer h3{font-size:1.8rem;line-height:.95;margin:.4rem 1.8rem 0 0}html[data-theme=swiss] .theme-lab-note{font-family:IBM Plex Mono,monospace;line-height:1.8;margin-top:.9rem}html[data-theme=swiss] .theme-lab-close:hover{color:var(--accent-magenta)}@keyframes swiss-rise{0%{opacity:0;transform:translateY(100vh) scaleY(.8)}25%{opacity:.08}to{opacity:0;transform:translateY(-12vh) scaleY(1.25)}}@keyframes swiss-trail-fade{0%{opacity:.8;transform:translate(-50%,-50%) scaleX(1)}to{opacity:0;transform:translate(-50%,-50%) scaleX(2.8)}}@media (max-width:900px){html[data-theme=swiss] .featured-project-shell{grid-template-columns:1fr}html[data-theme=swiss] .featured-project-actions,html[data-theme=swiss] .featured-project-header,html[data-theme=swiss] .featured-project-summary{grid-column:1;grid-row:auto;padding-left:0}html[data-theme=swiss] .system-detail-card,html[data-theme=swiss] .system-selector{grid-column:1;grid-row:auto}html[data-theme=swiss] .system-selector{margin-left:0;max-width:none}html[data-theme=swiss] .featured-project-shell:before{left:0;width:110px}html[data-theme=swiss] .featured-project-summary{max-width:none}html[data-theme=swiss] .system-selector{grid-template-columns:repeat(2,minmax(0,1fr))}html[data-theme=swiss] .skills-grid{grid-template-columns:1fr}}@media (max-width:768px){html[data-theme=swiss] .navbar{padding-top:.8rem}html[data-theme=swiss] .navbar-inner{padding:.85rem 0 .9rem;position:relative;width:95%}html[data-theme=swiss] .nav-links{display:none}html[data-theme=swiss] .nav-links.active{align-items:stretch;background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:0;box-shadow:none;display:flex;flex-direction:column;gap:0;left:0;padding:0;position:absolute;right:0;top:calc(100% + .8rem)}html[data-theme=swiss] .nav-links.active a{border-bottom:2px solid var(--primary-text-color);padding:1rem;text-align:left}html[data-theme=swiss] .nav-links.active a:last-child{border-bottom:none}html[data-theme=swiss] .hamburger-menu{background:#0000;border:none;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:30px}html[data-theme=swiss] .hamburger-bar{background:var(--primary-text-color);border-radius:0;height:2px;transition:all .3s ease-in-out;width:100%}html[data-theme=swiss] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=swiss] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=swiss] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=swiss] .hero{min-height:auto;padding:2rem 0 2.4rem}html[data-theme=swiss] .hero:before{height:10rem;top:0;width:100%}html[data-theme=swiss] .hero:after{bottom:2rem;height:12rem;right:-2rem;width:12rem}html[data-theme=swiss] .hero-content{gap:1.4rem;grid-template-columns:1fr;min-height:auto;padding:3rem 0 0;width:95%}html[data-theme=swiss] .hero-content:before{margin-left:0}html[data-theme=swiss] .hero-content:after{display:none}html[data-theme=swiss] .hero-content h1{font-size:clamp(3.2rem,16vw,5rem);grid-column:1;margin-left:0;max-width:none}html[data-theme=swiss] .hero-content p{grid-column:1;margin:0;max-width:none}html[data-theme=swiss] .about-text h2,html[data-theme=swiss] .skills-title,html[data-theme=swiss] .timeline-title{font-size:clamp(2.4rem,12vw,3.6rem);padding-left:0;text-align:left}html[data-theme=swiss] .timeline-line{left:18px}html[data-theme=swiss] .timeline-item,html[data-theme=swiss] .timeline-item:nth-child(2n),html[data-theme=swiss] .timeline-item:nth-child(odd){padding-left:3.7rem}html[data-theme=swiss] .timeline-dot,html[data-theme=swiss] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=swiss] .timeline-item:nth-child(odd) .timeline-dot{left:9px}html[data-theme=swiss] .timeline-content{padding:1.2rem 1.1rem 1.2rem 5.4rem}html[data-theme=swiss] .about-content{gap:1.6rem;grid-template-columns:1fr}html[data-theme=swiss] .about-text{padding-left:0}html[data-theme=swiss] .about-image{max-width:260px}html[data-theme=swiss] .project-body.side-by-side{flex-direction:column}html[data-theme=swiss] .project-body.side-by-side .project-details,html[data-theme=swiss] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=swiss] .featured-project-actions{flex-direction:column}html[data-theme=swiss] .theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}html[data-theme=swiss] .theme-lab-drawer,html[data-theme=swiss] .theme-lab-trigger{width:100%}}@media (min-width:769px){html[data-theme=swiss] .hamburger-menu{display:none}}html[data-theme=museum]{--bg-color:#f2eadf;--paper-color:#f9f4ecd6;--paper-strong:#fcf8f2f0;--primary-text-color:#181614;--secondary-text-color:#5e5650;--accent-cyan:#2a2724;--accent-magenta:#7a6652;--accent-gold:#a7865f;--border-color:#1816142e;--card-bg:#fcf8f2b8;--accent-cyan-glow:#18161414;--shadow-soft:0 22px 60px #18161412;--logo-badge-bg:#2b2927;--logo-badge-border:#1816142e;--nav-shell-bg:#fcf8f2c7;--nav-wash:linear-gradient(180deg,#f2eadffa,#f2eadfd6 70%,#0000);--hero-shell-bg:#0000;--button-inverse-text:#f8f1e8;--ghost-pill-bg:#18161405;--ghost-button-bg:#18161408;--surface-strong-bg:#ffffffb8;--surface-soft-bg:rgba(24,22,20,.035);--inner-highlight:#ffffff59}html[data-theme=museum] body{background:radial-gradient(circle at 14% 12%,#1816140a,#0000 24%),radial-gradient(circle at 84% 16%,#18161408,#0000 18%),linear-gradient(180deg,#ffffff73,#0000 32%),repeating-linear-gradient(0deg,rgba(24,22,20,.022),rgba(24,22,20,.022) 1px,#0000 0,#0000 74px),linear-gradient(180deg,#f5eee3,#f1e7da);color:var(--primary-text-color);font-family:Manrope,sans-serif}html[data-theme=museum] .navbar{background:var(--nav-wash);padding-top:1rem}html[data-theme=museum] .navbar-inner{-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;padding:1rem 0 .95rem;width:min(94%,1260px)}html[data-theme=museum] .logo-title{gap:1.1rem}html[data-theme=museum] .nav-logo{background:var(--logo-badge-bg);border:1px solid var(--primary-text-color);border-radius:0;box-shadow:none;height:62px;padding:.45rem;width:62px}html[data-theme=museum] .nav-name{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;letter-spacing:-.02em}html[data-theme=museum] .nav-links{gap:1.2rem}html[data-theme=museum] .nav-links a{color:var(--secondary-text-color);font-size:.78rem;font-weight:700;letter-spacing:.18em;margin-left:0;padding:.3rem 0;position:relative;text-transform:uppercase}html[data-theme=museum] .nav-links a:after{background:var(--primary-text-color);bottom:-.1rem;content:"";height:1px;left:0;position:absolute;right:0;transform:scaleX(0);transform-origin:left;transition:transform .2s ease}html[data-theme=museum] .nav-links a:hover{color:var(--primary-text-color);transform:none}html[data-theme=museum] .nav-links a:hover:after{transform:scaleX(1)}html[data-theme=museum] .hero{min-height:92vh;padding:2.5rem 0 3.8rem;text-align:left}html[data-theme=museum] .hero:before{background:radial-gradient(circle,#18161414,#0000 72%);border-radius:50%;filter:blur(8px);height:26rem;left:-3rem;opacity:.55;top:10%;width:26rem}html[data-theme=museum] .hero:after{background:linear-gradient(180deg,#1816140a,#18161400),linear-gradient(90deg,#18161417,#18161417) 0/1px 100% no-repeat,linear-gradient(90deg,#18161417,#18161417) 100%/1px 100% no-repeat,linear-gradient(180deg,#18161417,#18161417) top/100% 1px no-repeat,linear-gradient(180deg,#18161417,#18161417) bottom/100% 1px no-repeat;border-radius:0;bottom:8%;filter:none;height:34rem;opacity:.38;right:4%;width:24rem}html[data-theme=museum] .hero-content{grid-gap:2rem 4rem;align-items:start;background:#0000;border:none;border-radius:0;box-shadow:none;display:grid;gap:2rem 4rem;grid-template-columns:minmax(0,.66fr) minmax(280px,.34fr);margin:auto;min-height:72vh;padding:5.25rem 0 3rem;position:relative;width:min(94%,1260px)}html[data-theme=museum] .hero-content:before{color:var(--secondary-text-color);content:"Exhibition Catalog / Portfolio / 2026";display:block;font-size:.76rem;font-weight:700;grid-column:1/-1;letter-spacing:.24em;text-transform:uppercase}html[data-theme=museum] .hero-content:after{color:var(--secondary-text-color);content:"Gallery No. 04";font-size:.74rem;font-weight:700;letter-spacing:.18em;position:absolute;right:-.25rem;text-transform:uppercase;top:5.35rem;transform:rotate(180deg);writing-mode:vertical-rl}html[data-theme=museum] .hero-content h1{font-family:Cormorant Garamond,serif;font-size:clamp(4.6rem,9.4vw,8.3rem);font-weight:600;grid-column:1;letter-spacing:-.05em;line-height:.88;margin-bottom:0;max-width:8ch}html[data-theme=museum] .hero-content p{align-self:end;border-top:1px solid var(--primary-text-color);color:var(--secondary-text-color);font-size:.97rem;grid-column:2;line-height:2;margin:0 0 1.2rem auto;max-width:24rem;padding-top:1.2rem}html[data-theme=museum] .glitch{color:var(--primary-text-color)}html[data-theme=museum] .glitch:before{color:#7a66525c;opacity:.6;transform:translate(-3px,1px)}html[data-theme=museum] .glitch:after{color:#1816142e;opacity:.55;transform:translate(3px,-1px)}html[data-theme=museum] .particles-bg{z-index:-1}html[data-theme=museum] .particle{animation:museum-rise 14s linear infinite;background:#1816141f;border-radius:999px;box-shadow:0 0 18px #1816140d}html[data-theme=museum] .mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}html[data-theme=museum] .trail-particle{animation:museum-trail-fade .8s forwards;background:linear-gradient(90deg,#0000 calc(50% - 4px),currentColor calc(50% - 4px) calc(50% + 4px),#0000 calc(50% + 4px)),linear-gradient(180deg,#0000 calc(50% - 4px),currentColor calc(50% - 4px) calc(50% + 4px),#0000 calc(50% + 4px));border:1px solid;border-radius:0;box-shadow:none;height:18px;opacity:.22;position:absolute;transform:translate(-50%,-50%);width:18px}html[data-theme=museum] .contact-container,html[data-theme=museum] .featured-project-section,html[data-theme=museum] .skills-container,html[data-theme=museum] .timeline-container{width:min(94%,1260px)}html[data-theme=museum] .featured-project-section{margin:0 auto 5.4rem}html[data-theme=museum] .featured-project-shell{grid-gap:1.6rem 2.8rem;align-items:start;background:linear-gradient(180deg,#ffffff38,#fff0),#0000;border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;display:grid;gap:1.6rem 2.8rem;grid-template-columns:minmax(0,.58fr) minmax(280px,.42fr);padding:2.8rem 0 3rem;position:relative}html[data-theme=museum] .featured-project-shell:before{background:var(--bg-color);color:var(--secondary-text-color);content:"Collection Overview";font-size:.74rem;font-weight:700;left:0;letter-spacing:.18em;padding-right:1rem;position:absolute;text-transform:uppercase;top:-.72rem}html[data-theme=museum] .featured-project-shell:after{background:var(--primary-text-color);bottom:-1px;content:"";height:1px;position:absolute;right:0;width:16%}html[data-theme=museum] .featured-project-header{grid-column:1;margin:0;padding-right:1.5rem}html[data-theme=museum] .featured-project-summary{border-top:1px solid var(--primary-text-color);grid-column:2;margin:0;padding-top:.95rem}html[data-theme=museum] .system-selector{grid-gap:0;border-bottom:1px solid #18161424;border-top:1px solid #18161424;display:grid;gap:0;grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr));margin:.5rem 0 0}html[data-theme=museum] .system-selector-button{background:#0000;border:none;border-radius:0;border-right:1px solid #18161424;color:var(--secondary-text-color);font-size:.84rem;font-weight:700;letter-spacing:.08em;padding:.95rem 1rem;text-align:left;text-transform:uppercase;transition:background .2s ease,color .2s ease}html[data-theme=museum] .system-selector-button:last-child{border-right:none}html[data-theme=museum] .system-selector-button.active,html[data-theme=museum] .system-selector-button:hover{background:var(--primary-text-color);color:var(--button-inverse-text);transform:none}html[data-theme=museum] .system-detail-card{background:linear-gradient(90deg,#1816140a,#1816140a) 0/1px 100% no-repeat,linear-gradient(180deg,#ffffff6b,#fff0) top/100% 100% no-repeat,var(--paper-color);border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;grid-column:1/-1;padding:2rem 2rem 2rem 8rem;position:relative}html[data-theme=museum] .system-detail-card:before{color:var(--secondary-text-color);content:"Object Note";font-size:.72rem;font-weight:700;left:1.6rem;letter-spacing:.18em;position:absolute;text-transform:uppercase;top:1.45rem}html[data-theme=museum] .system-detail-card:after{background:#18161429;bottom:1.3rem;content:"";left:6rem;position:absolute;top:1.3rem;width:1px}html[data-theme=museum] .featured-project-actions{gap:.9rem;grid-column:1/-1;justify-content:flex-start;margin-top:.4rem}html[data-theme=museum] .featured-project-kicker,html[data-theme=museum] .project-media-kicker,html[data-theme=museum] .system-detail-kicker,html[data-theme=museum] .theme-lab-kicker,html[data-theme=museum] .theme-lab-trigger-label{color:var(--secondary-text-color);display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase}html[data-theme=museum] .about-text h2,html[data-theme=museum] .contact-tile h2,html[data-theme=museum] .featured-project-header h2,html[data-theme=museum] .project-details h3,html[data-theme=museum] .project-header h1,html[data-theme=museum] .project-media-placeholder h2,html[data-theme=museum] .skill-category h3,html[data-theme=museum] .skills-title,html[data-theme=museum] .system-detail-topbar h3,html[data-theme=museum] .theme-lab-drawer h3,html[data-theme=museum] .theme-lab-trigger strong,html[data-theme=museum] .timeline-title{font-family:Cormorant Garamond,serif;font-weight:600;letter-spacing:-.03em}html[data-theme=museum] .featured-project-header h2{font-size:clamp(3.4rem,6vw,5.7rem);line-height:.9;margin:.75rem 0 .9rem;max-width:10ch}html[data-theme=museum] .system-detail-topbar h3{font-size:clamp(2rem,3.8vw,3.2rem);line-height:.94}html[data-theme=museum] .about-text p,html[data-theme=museum] .contact-item,html[data-theme=museum] .featured-project-header p,html[data-theme=museum] .featured-project-summary p,html[data-theme=museum] .project-details p,html[data-theme=museum] .project-media-placeholder p,html[data-theme=museum] .system-detail-stack,html[data-theme=museum] .system-detail-summary,html[data-theme=museum] .system-log-line,html[data-theme=museum] .theme-lab-note,html[data-theme=museum] .timeline-project-preview{color:var(--secondary-text-color)}html[data-theme=museum] .featured-project-header p,html[data-theme=museum] .featured-project-summary p,html[data-theme=museum] .project-details p,html[data-theme=museum] .project-media-placeholder p,html[data-theme=museum] .system-detail-stack,html[data-theme=museum] .system-detail-summary{line-height:1.95}html[data-theme=museum] .system-detail-stack strong{color:var(--primary-text-color)}html[data-theme=museum] .system-log{grid-gap:.55rem;display:grid;gap:.55rem}html[data-theme=museum] .system-log-line{align-items:flex-start;display:flex;gap:.65rem;line-height:1.8}html[data-theme=museum] .system-log-prompt{color:var(--accent-magenta);font-weight:700}html[data-theme=museum] .featured-project-button,html[data-theme=museum] .project-live-link,html[data-theme=museum] .theme-lab-button,html[data-theme=museum] .timeline-read-more{border-radius:0;transition:transform .2s ease,background .2s ease,color .2s ease,border-color .2s ease}html[data-theme=museum] .featured-project-button,html[data-theme=museum] .project-live-link{font-size:.82rem;font-weight:700;letter-spacing:.14em;padding:.95rem 1.1rem;text-transform:uppercase}html[data-theme=museum] .featured-project-button.primary,html[data-theme=museum] .project-live-link,html[data-theme=museum] .theme-lab-button.primary{background:var(--primary-text-color);border:1px solid var(--primary-text-color);color:var(--button-inverse-text)}html[data-theme=museum] .featured-project-button.secondary{background:#0000;border:1px solid var(--primary-text-color);color:var(--primary-text-color)}html[data-theme=museum] .featured-project-button:hover,html[data-theme=museum] .project-live-link:hover,html[data-theme=museum] .theme-lab-button:hover{transform:translateY(-2px)}html[data-theme=museum] .featured-project-button.secondary:hover{background:#1816140d}html[data-theme=museum] .timeline-container{margin:5rem auto}html[data-theme=museum] .skills-title,html[data-theme=museum] .timeline-title{border-bottom:1px solid var(--primary-text-color);font-size:clamp(3rem,5vw,4.8rem);margin-bottom:2.4rem;padding-bottom:.8rem;text-align:left}html[data-theme=museum] .about-text h2{font-size:clamp(2.9rem,4.8vw,4.1rem);margin-bottom:1.2rem;text-align:left}html[data-theme=museum] .timeline{counter-reset:plate;padding-top:.6rem}html[data-theme=museum] .timeline-line{background:linear-gradient(180deg,#0000,#1816143d,#1816143d,#0000);left:11.5%;transform:none;width:1px}html[data-theme=museum] .timeline-item,html[data-theme=museum] .timeline-item:nth-child(2n),html[data-theme=museum] .timeline-item:nth-child(odd){counter-increment:plate;left:0;margin-bottom:1.35rem;padding:0 0 0 18%;text-align:left;width:auto}html[data-theme=museum] .timeline-dot,html[data-theme=museum] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=museum] .timeline-item:nth-child(odd) .timeline-dot{background:var(--paper-strong);border:2px solid var(--primary-text-color);border-radius:999px;height:14px;left:calc(11.5% - 7px);right:auto;top:1.15rem;width:14px}html[data-theme=museum] .timeline-item:hover .timeline-dot{background:var(--primary-text-color);transform:scale(1.04)}html[data-theme=museum] .timeline-content{background:linear-gradient(180deg,#ffffff42,#fff0),var(--paper-color);border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;overflow:hidden;padding:1.55rem 1.6rem 1.55rem 8.2rem;position:relative;transition:transform .25s ease,background .25s ease}html[data-theme=museum] .timeline-content:before{color:var(--secondary-text-color);content:"Plate " counter(plate,decimal-leading-zero);font-size:.72rem;font-weight:700;left:1.5rem;letter-spacing:.18em;position:absolute;text-transform:uppercase;top:1.45rem}html[data-theme=museum] .timeline-content:after{background:#18161429;bottom:1.25rem;content:"";left:6.1rem;position:absolute;top:1.25rem;width:1px}html[data-theme=museum] .timeline-item:hover .timeline-content{background:linear-gradient(180deg,#ffffff57,#fff0),var(--paper-strong);box-shadow:none;transform:translateX(8px)}html[data-theme=museum] .timeline-date,html[data-theme=museum] .timeline-project-preview,html[data-theme=museum] .timeline-project-title{position:relative;z-index:1}html[data-theme=museum] .timeline-date{color:var(--accent-magenta);font-size:.74rem;font-weight:700;letter-spacing:.16em;margin-bottom:.65rem;text-transform:uppercase}html[data-theme=museum] .timeline-project-title{font-family:Cormorant Garamond,serif;font-size:2.2rem;font-weight:600;line-height:.96;margin-bottom:.7rem}html[data-theme=museum] .timeline-project-preview{font-size:.92rem;line-height:1.85}html[data-theme=museum] .timeline-read-more{color:var(--primary-text-color);display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.16em;margin-top:.85rem;text-transform:uppercase}html[data-theme=museum] .about-container{padding:4.6rem 0}html[data-theme=museum] .about-content{align-items:start;gap:2.8rem;grid-template-columns:minmax(0,.66fr) minmax(260px,.34fr);width:min(94%,1260px)}html[data-theme=museum] .about-text{background:#0000;border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;padding:1.3rem 0 1rem;position:relative}html[data-theme=museum] .about-text:before{color:var(--secondary-text-color);content:"Curator's Note";display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.18em;margin-bottom:.8rem;text-transform:uppercase}html[data-theme=museum] .about-text p{line-height:2;margin-bottom:1rem;max-width:70ch}html[data-theme=museum] .about-image{justify-self:end;max-width:320px;position:relative}html[data-theme=museum] .about-image:before{border:1px solid #18161424;content:"";inset:1.2rem -1.2rem -1.2rem 1.2rem;pointer-events:none;position:absolute}html[data-theme=museum] .about-image:after{bottom:-2rem;color:var(--secondary-text-color);content:"Archival Portrait";font-size:.7rem;font-weight:700;left:0;letter-spacing:.18em;position:absolute;text-transform:uppercase}html[data-theme=museum] .about-image img{background:var(--paper-strong);border:1px solid var(--primary-text-color);border-radius:0;box-shadow:none;filter:grayscale(100%) contrast(1.04);padding:.8rem;width:100%}html[data-theme=museum] .about-image:hover img{filter:grayscale(18%) contrast(1);transform:translateY(-3px)}html[data-theme=museum] .skills-container{margin:5rem auto}html[data-theme=museum] .skills-grid{gap:1.7rem;grid-template-columns:repeat(3,minmax(0,1fr))}html[data-theme=museum] .skill-category{background:#0000;border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;min-height:100%;padding:1.45rem 0 1.1rem;position:relative}html[data-theme=museum] .skill-category:before{color:var(--secondary-text-color);display:block;font-size:.7rem;font-weight:700;letter-spacing:.18em;margin-bottom:.9rem;text-transform:uppercase}html[data-theme=museum] .skill-category:first-child:before{content:"Collection I"}html[data-theme=museum] .skill-category:nth-child(2):before{content:"Collection II"}html[data-theme=museum] .skill-category:nth-child(3):before{content:"Collection III"}html[data-theme=museum] .skill-category .border-svg{display:none}html[data-theme=museum] .skill-category h3{font-size:2.05rem;margin-bottom:1rem}html[data-theme=museum] .skill-category ul{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:1fr}html[data-theme=museum] .skill-category li{background:#0000;border:none;border-bottom:1px solid #1816141f;border-radius:0;color:var(--secondary-text-color);font-size:.89rem;padding:.55rem .1rem}html[data-theme=museum] .skill-category li:last-child{border-bottom:none}html[data-theme=museum] .skill-category:hover{background:#18161405;transform:translateY(-4px)}html[data-theme=museum] .contact-tile,html[data-theme=museum] .terminal-container{background:var(--paper-strong);border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none}html[data-theme=museum] .terminal-container{width:min(94%,980px)}html[data-theme=museum] .terminal-header{background:#ffffff52;border-bottom:1px solid #18161424;padding:.95rem 1rem}html[data-theme=museum] .terminal-header-dot{border-radius:0}html[data-theme=museum] .terminal-header-dot.green,html[data-theme=museum] .terminal-header-dot.red,html[data-theme=museum] .terminal-header-dot.yellow{background:var(--primary-text-color)}html[data-theme=museum] .terminal-header span{color:var(--secondary-text-color);font-size:.72rem;font-weight:700;letter-spacing:.2em}html[data-theme=museum] .terminal-body{background:repeating-linear-gradient(0deg,#0000,#0000 31px,rgba(24,22,20,.035) 0,rgba(24,22,20,.035) 32px)}html[data-theme=museum] .contact-item,html[data-theme=museum] .terminal-body,html[data-theme=museum] .terminal-input,html[data-theme=museum] .terminal-line{font-family:Manrope,sans-serif}html[data-theme=museum] .terminal-line{font-size:.95rem}html[data-theme=museum] .contact-item a,html[data-theme=museum] .prompt-text,html[data-theme=museum] .terminal-line.link a,html[data-theme=museum] .terminal-line.success{color:var(--primary-text-color)}html[data-theme=museum] .contact-item a:hover,html[data-theme=museum] .terminal-line.error,html[data-theme=museum] .terminal-line.link a:hover{color:var(--accent-magenta)}html[data-theme=museum] .terminal-input{caret-color:var(--accent-magenta)}html[data-theme=museum] .project-page-container{padding:2.2rem 0 4.4rem;width:min(94%,1260px)}html[data-theme=museum] .project-header{align-items:flex-start;border-bottom:1px solid var(--primary-text-color);margin-bottom:2.1rem;padding:.5rem 0 2rem;text-align:left}html[data-theme=museum] .project-header h1{font-size:clamp(3.6rem,7vw,6rem);line-height:.9;max-width:12ch}html[data-theme=museum] .project-header span{color:var(--secondary-text-color);font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase}html[data-theme=museum] .back-link{color:var(--primary-text-color);font-size:.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}html[data-theme=museum] .project-body.side-by-side{gap:2.2rem}html[data-theme=museum] .main-image-container{margin:0 auto 1rem;max-width:760px;width:100%}html[data-theme=museum] .main-image-container:before{border:1px solid #18161424;content:"";inset:1rem -1rem -1rem 1rem;position:absolute;z-index:-1}html[data-theme=museum] .main-image-container:after{color:var(--secondary-text-color);content:"Image Plate";font-size:.7rem;font-weight:700;left:0;letter-spacing:.18em;position:absolute;text-transform:uppercase;top:-1.65rem}html[data-theme=museum] .main-image-container.placeholder-media:after{display:none}html[data-theme=museum] .main-image,html[data-theme=museum] .main-video{background:var(--paper-strong);border:1px solid var(--primary-text-color);border-radius:0;box-shadow:none}html[data-theme=museum] .main-image-container:hover .main-image,html[data-theme=museum] .main-image-container:hover .main-video{transform:translateY(-3px)}html[data-theme=museum] .thumbnail-container{gap:.7rem}html[data-theme=museum] .thumbnail-image{background:var(--paper-strong);border:1px solid #18161424;border-radius:0;padding:.18rem}html[data-theme=museum] .thumbnail-image:hover{border-color:var(--primary-text-color);transform:none}html[data-theme=museum] .thumbnail-image.active{border-color:var(--primary-text-color);box-shadow:none}html[data-theme=museum] .project-details,html[data-theme=museum] .project-media-placeholder{background:var(--paper-color);border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;padding:2rem 0}html[data-theme=museum] .project-media-placeholder{min-height:420px;padding-left:0;padding-right:0}html[data-theme=museum] .project-details{padding-left:0;padding-right:0}html[data-theme=museum] .project-details h3,html[data-theme=museum] .project-media-placeholder h2{font-size:2.35rem;line-height:.97}html[data-theme=museum] .footer{background:#0000;border-top:1px solid var(--primary-text-color);color:var(--secondary-text-color)}html[data-theme=museum] .theme-lab-drawer,html[data-theme=museum] .theme-lab-trigger{background:var(--paper-strong);border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none}html[data-theme=museum] .theme-lab-trigger{min-width:176px;padding:.95rem 1rem}html[data-theme=museum] .theme-lab-trigger strong{font-size:1.55rem;margin-top:.35rem}html[data-theme=museum] .theme-lab-drawer{padding:1.4rem 1.4rem 1.25rem;width:min(370px,calc(100vw - 2rem))}html[data-theme=museum] .theme-lab-drawer h3{font-size:2rem;line-height:.96;margin:.55rem 1.8rem 0 0}html[data-theme=museum] .theme-lab-note{line-height:1.8;margin-top:.85rem}html[data-theme=museum] .theme-lab-close:hover{color:var(--primary-text-color)}@keyframes museum-rise{0%{opacity:0;transform:translateY(110vh) scale(.85)}16%{opacity:.24}to{opacity:0;transform:translateY(-12vh) scale(1.15)}}@keyframes museum-trail-fade{0%{opacity:.22;transform:translate(-50%,-50%) scale(.92) rotate(0deg)}to{opacity:0;transform:translate(-50%,-50%) scale(1.8) rotate(10deg)}}@media (max-width:900px){html[data-theme=museum] .featured-project-shell{grid-template-columns:1fr}html[data-theme=museum] .featured-project-actions,html[data-theme=museum] .featured-project-header,html[data-theme=museum] .featured-project-summary{grid-column:1}html[data-theme=museum] .featured-project-summary{max-width:none}html[data-theme=museum] .system-selector{grid-template-columns:repeat(2,minmax(0,1fr))}html[data-theme=museum] .skills-grid{grid-template-columns:1fr}}@media (max-width:768px){html[data-theme=museum] .navbar{padding-top:.8rem}html[data-theme=museum] .navbar-inner{padding:.85rem 0 .9rem;position:relative;width:95%}html[data-theme=museum] .nav-links{display:none}html[data-theme=museum] .nav-links.active{align-items:stretch;background:var(--paper-strong);border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:1px solid var(--primary-text-color);box-shadow:none;display:flex;flex-direction:column;gap:0;left:0;padding:0;position:absolute;right:0;top:calc(100% + .8rem)}html[data-theme=museum] .nav-links.active a{border-bottom:1px solid #1816141f;padding:1rem 0;text-align:left}html[data-theme=museum] .nav-links.active a:last-child{border-bottom:none}html[data-theme=museum] .nav-links.active a:after{display:none}html[data-theme=museum] .hamburger-menu{background:#0000;border:none;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:30px}html[data-theme=museum] .hamburger-bar{background:var(--primary-text-color);border-radius:0;height:1px;transition:all .3s ease-in-out;width:100%}html[data-theme=museum] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=museum] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=museum] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=museum] .hero{min-height:auto;padding:2rem 0 2.8rem}html[data-theme=museum] .hero:before{height:14rem;left:-3rem;top:4rem;width:14rem}html[data-theme=museum] .hero:after{bottom:2rem;height:18rem;right:-1rem;width:12rem}html[data-theme=museum] .hero-content{gap:1.4rem;grid-template-columns:1fr;min-height:auto;padding:3.2rem 0 0;width:95%}html[data-theme=museum] .hero-content:after{display:none}html[data-theme=museum] .hero-content h1{font-size:clamp(3.5rem,16vw,5.4rem);grid-column:1;max-width:none}html[data-theme=museum] .hero-content p{grid-column:1;margin:0;max-width:none}html[data-theme=museum] .about-text h2,html[data-theme=museum] .skills-title,html[data-theme=museum] .timeline-title{font-size:clamp(2.4rem,12vw,3.5rem)}html[data-theme=museum] .timeline-line{left:18px}html[data-theme=museum] .timeline-item,html[data-theme=museum] .timeline-item:nth-child(2n),html[data-theme=museum] .timeline-item:nth-child(odd){padding-left:3.8rem}html[data-theme=museum] .timeline-dot,html[data-theme=museum] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=museum] .timeline-item:nth-child(odd) .timeline-dot{left:11px}html[data-theme=museum] .timeline-content{padding:1.2rem 1rem 1.2rem 5.8rem}html[data-theme=museum] .timeline-content:after{left:4.4rem}html[data-theme=museum] .about-content{gap:2.1rem;grid-template-columns:1fr}html[data-theme=museum] .about-image{justify-self:start;max-width:250px}html[data-theme=museum] .about-image:after{bottom:-1.6rem}html[data-theme=museum] .project-body.side-by-side{flex-direction:column}html[data-theme=museum] .project-body.side-by-side .project-details,html[data-theme=museum] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=museum] .featured-project-actions{flex-direction:column}html[data-theme=museum] .system-selector{grid-template-columns:1fr}html[data-theme=museum] .system-selector-button{border-bottom:1px solid #18161424;border-right:none}html[data-theme=museum] .system-selector-button:last-child{border-bottom:none}html[data-theme=museum] .system-detail-card{padding:5rem 1.1rem 1.35rem}html[data-theme=museum] .system-detail-card:after{bottom:auto;height:1px;left:1.1rem;right:1.1rem;top:3.7rem;width:auto}html[data-theme=museum] .theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}html[data-theme=museum] .theme-lab-drawer,html[data-theme=museum] .theme-lab-trigger{width:100%}}@media (min-width:769px){html[data-theme=museum] .hamburger-menu{display:none}}html[data-theme=manuscript]{--bg-color:#ece1c9;--paper-color:#f6eeddd6;--paper-strong:#faf4e8f2;--primary-text-color:#20160f;--secondary-text-color:#6a5747;--accent-cyan:#6d1821;--accent-magenta:#8c6a34;--accent-gold:#c3a05d;--border-color:#20160f2e;--card-bg:#f7f0e0bd;--accent-cyan-glow:#6d18212e;--shadow-soft:0 20px 56px #2d1d1217;--logo-badge-bg:#3a1418;--logo-badge-border:#c3a05d6b;--nav-shell-bg:#f7f0e0c7;--nav-wash:linear-gradient(180deg,#ece1c9fa,#ece1c9d1 72%,#0000);--hero-shell-bg:linear-gradient(180deg,#fbf7ee85,#faf5e93d);--button-inverse-text:#f7efdf;--ghost-pill-bg:#6d18210a;--ghost-button-bg:#6d18210d;--surface-strong-bg:#fffaf1c7;--surface-soft-bg:#6d18210a;--inner-highlight:#ffffff57}html[data-theme=manuscript] body{background:radial-gradient(circle at 12% 14%,#8c6a341a,#0000 24%),radial-gradient(circle at 86% 16%,#6d182114,#0000 18%),radial-gradient(circle at 50% 82%,#c3a05d14,#0000 26%),linear-gradient(180deg,#ffffff52,#0000 24%),repeating-linear-gradient(90deg,rgba(32,22,15,.018),rgba(32,22,15,.018) 1px,#0000 0,#0000 96px),linear-gradient(180deg,#f1e6cf,#eadcc2);color:var(--primary-text-color);font-family:EB Garamond,serif}html[data-theme=manuscript] .navbar{background:var(--nav-wash);padding-top:1rem}html[data-theme=manuscript] .navbar-inner{-webkit-backdrop-filter:none;backdrop-filter:none;background:linear-gradient(180deg,#ffffff2e,#fff0),#0000;border:none;border-bottom:1px solid var(--primary-text-color);border-radius:0;border-top:2px solid var(--accent-cyan);box-shadow:none;padding:1rem 0 .92rem;width:min(94%,1260px)}html[data-theme=manuscript] .logo-title{gap:1rem}html[data-theme=manuscript] .nav-logo{background:radial-gradient(circle at 30% 30%,#c3a05d47,#0000 44%),linear-gradient(135deg,#4d1a1e,#2b0d11);border:1px solid var(--logo-badge-border);border-radius:0;box-shadow:inset 0 0 0 1px #fff5dd1f;height:64px;padding:.4rem;width:64px}html[data-theme=manuscript] .nav-name{color:var(--primary-text-color);font-family:Cinzel Decorative,serif;font-size:1.8rem;font-weight:700;letter-spacing:.04em}html[data-theme=manuscript] .nav-links{gap:1rem}html[data-theme=manuscript] .nav-links a{color:var(--secondary-text-color);font-family:Source Sans\ 3,sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.18em;margin-left:0;padding:.35rem .15rem;position:relative;text-transform:uppercase}html[data-theme=manuscript] .nav-links a:after,html[data-theme=manuscript] .nav-links a:before{background:var(--accent-cyan);content:"";height:1px;left:0;position:absolute;right:0;transform:scaleX(0);transition:transform .22s ease}html[data-theme=manuscript] .nav-links a:before{top:0;transform-origin:right}html[data-theme=manuscript] .nav-links a:after{bottom:0;transform-origin:left}html[data-theme=manuscript] .nav-links a:hover{color:var(--accent-cyan);transform:none}html[data-theme=manuscript] .nav-links a:hover:after,html[data-theme=manuscript] .nav-links a:hover:before{transform:scaleX(1)}html[data-theme=manuscript] .hero{min-height:92vh;padding:2.5rem 0 3.4rem;text-align:left}html[data-theme=manuscript] .hero:before{background:radial-gradient(circle,#c3a05d29,#0000 72%);border-radius:50%;filter:blur(18px);height:30rem;left:-7rem;opacity:.7;top:2%;width:30rem}html[data-theme=manuscript] .hero:after{background:radial-gradient(circle at 50% 18%,#c3a05d3d,#0000 36%),linear-gradient(180deg,#6d18211f,#6d182100);border-radius:50% 50% 0 0;bottom:12%;filter:blur(6px);height:26rem;opacity:.62;right:3.5%;width:18rem}html[data-theme=manuscript] .hero-content{grid-gap:2.2rem 3rem;align-items:start;background:linear-gradient(180deg,#fffcf56b,#fffcf500),var(--hero-shell-bg);border:1px solid #6d18212e;border-radius:0;box-shadow:inset 0 0 0 1px #c3a05d3d,var(--shadow-soft);display:grid;gap:2.2rem 3rem;grid-template-columns:minmax(0,.67fr) minmax(280px,.33fr);margin:auto;min-height:74vh;overflow:hidden;padding:4.8rem 3rem 3rem;position:relative;width:min(94%,1260px)}html[data-theme=manuscript] .hero-content:before{color:var(--accent-cyan);content:"Collected Works";display:block;font-family:Cinzel Decorative,serif;font-size:.92rem;font-weight:700;grid-column:1/-1;letter-spacing:.24em;text-transform:uppercase}html[data-theme=manuscript] .hero-content:after{color:var(--secondary-text-color);content:"Archive Edition / 2026";font-family:Source Sans\ 3,sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.18em;position:absolute;right:1.65rem;text-transform:uppercase;top:1.55rem}html[data-theme=manuscript] .hero-content h1{font-family:Cinzel Decorative,serif;font-size:clamp(4rem,8.6vw,7rem);font-weight:700;grid-column:1;letter-spacing:.02em;line-height:.92;margin-bottom:0;max-width:8ch}html[data-theme=manuscript] .hero-content p{align-self:end;background:#fff9ee8a;border-left:2px solid var(--accent-gold);box-shadow:inset 0 0 0 1px #c3a05d29;color:var(--secondary-text-color);font-size:1rem;grid-column:2;line-height:1.9;margin:0 0 1.1rem auto;max-width:25rem;padding:1.2rem 1.25rem 1.2rem 1.45rem}html[data-theme=manuscript] .glitch{color:var(--primary-text-color)}html[data-theme=manuscript] .glitch:after,html[data-theme=manuscript] .glitch:before{content:none;opacity:0}html[data-theme=manuscript] .glitch:first-letter{color:var(--accent-cyan);font-size:1.25em}html[data-theme=manuscript] .particles-bg{z-index:-1}html[data-theme=manuscript] .particle{animation:manuscript-rise 15s linear infinite;background:radial-gradient(circle,#c3a05d57,#6d182105 70%,#0000 72%);border-radius:999px;filter:blur(1px)}html[data-theme=manuscript] .mouse-trail-container{inset:0;pointer-events:none;position:fixed;z-index:9999}html[data-theme=manuscript] .trail-particle{animation:manuscript-trail-fade .95s forwards;background:linear-gradient(90deg,#0000 calc(50% - 1px),currentColor calc(50% - 1px) calc(50% + 1px),#0000 calc(50% + 1px)),linear-gradient(180deg,#0000 calc(50% - 1px),currentColor calc(50% - 1px) calc(50% + 1px),#0000 calc(50% + 1px));border:1px solid;border-radius:0;box-shadow:0 0 12px #c3a05d24;height:18px;opacity:.22;position:absolute;transform:translate(-50%,-50%) rotate(45deg);width:18px}html[data-theme=manuscript] .contact-container,html[data-theme=manuscript] .featured-project-section,html[data-theme=manuscript] .skills-container,html[data-theme=manuscript] .timeline-container{width:min(94%,1260px)}html[data-theme=manuscript] .featured-project-shell{background:linear-gradient(180deg,#fffdf85c,#fffdf800),var(--paper-color);border:1px solid #6d18212e;border-radius:0;box-shadow:inset 0 0 0 1px #c3a05d38,var(--shadow-soft);overflow:hidden;padding:2.7rem 2.4rem 2.5rem;position:relative}html[data-theme=manuscript] .featured-project-shell:after,html[data-theme=manuscript] .featured-project-shell:before{border:1px solid #c3a05d47;content:"";height:88px;pointer-events:none;position:absolute;width:88px}html[data-theme=manuscript] .featured-project-shell:before{border-bottom:none;border-right:none;left:12px;top:12px}html[data-theme=manuscript] .featured-project-shell:after{border-left:none;border-top:none;bottom:12px;right:12px}html[data-theme=manuscript] .featured-project-kicker,html[data-theme=manuscript] .project-media-kicker,html[data-theme=manuscript] .system-detail-kicker,html[data-theme=manuscript] .theme-lab-kicker,html[data-theme=manuscript] .theme-lab-trigger-label{color:var(--accent-cyan);font-family:Source Sans\ 3,sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase}html[data-theme=manuscript] .about-text h2,html[data-theme=manuscript] .contact-tile h2,html[data-theme=manuscript] .featured-project-header h2,html[data-theme=manuscript] .project-details h3,html[data-theme=manuscript] .project-header h1,html[data-theme=manuscript] .project-media-placeholder h2,html[data-theme=manuscript] .skill-category h3,html[data-theme=manuscript] .skills-title,html[data-theme=manuscript] .system-detail-topbar h3,html[data-theme=manuscript] .theme-lab-drawer h3,html[data-theme=manuscript] .theme-lab-trigger strong,html[data-theme=manuscript] .timeline-title{font-family:Cinzel Decorative,serif;font-weight:700;letter-spacing:.02em}html[data-theme=manuscript] .featured-project-header h2{font-size:clamp(3rem,5.8vw,5rem);line-height:.94;margin:.7rem 0 .9rem;max-width:12ch}html[data-theme=manuscript] .about-text p,html[data-theme=manuscript] .contact-item,html[data-theme=manuscript] .featured-project-header p,html[data-theme=manuscript] .featured-project-summary p,html[data-theme=manuscript] .project-details p,html[data-theme=manuscript] .project-media-placeholder p,html[data-theme=manuscript] .system-detail-stack,html[data-theme=manuscript] .system-detail-summary,html[data-theme=manuscript] .system-log-line,html[data-theme=manuscript] .theme-lab-note,html[data-theme=manuscript] .timeline-project-preview{color:var(--secondary-text-color)}html[data-theme=manuscript] .featured-project-summary{background:#fffaf17a;border-left:2px solid var(--accent-gold);margin:1.2rem 0 1.6rem;padding:1rem 1.2rem 1rem 1.5rem;position:relative}html[data-theme=manuscript] .featured-project-summary:before{color:var(--accent-cyan);content:"---";font-family:Source Sans\ 3,sans-serif;font-size:.7rem;font-weight:700;left:1.45rem;letter-spacing:.16em;position:absolute;text-transform:uppercase;top:.6rem}html[data-theme=manuscript] .featured-project-summary p{line-height:1.9;padding-top:1rem}html[data-theme=manuscript] .system-selector{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.4rem}html[data-theme=manuscript] .system-selector-button{background:#fffaf18a;border:1px solid #6d182133;border-radius:0;box-shadow:inset 0 0 0 1px #c3a05d29;color:var(--secondary-text-color);font-family:Source Sans\ 3,sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;padding:.82rem 1.1rem;text-transform:uppercase;transition:transform .22s ease,background .22s ease,color .22s ease}html[data-theme=manuscript] .system-selector-button.active,html[data-theme=manuscript] .system-selector-button:hover{background:var(--accent-cyan);color:var(--button-inverse-text);transform:translateY(-2px)}html[data-theme=manuscript] .about-text,html[data-theme=manuscript] .contact-tile,html[data-theme=manuscript] .project-details,html[data-theme=manuscript] .project-media-placeholder,html[data-theme=manuscript] .skill-category,html[data-theme=manuscript] .system-detail-card,html[data-theme=manuscript] .terminal-container,html[data-theme=manuscript] .theme-lab-drawer,html[data-theme=manuscript] .theme-lab-trigger{background:linear-gradient(180deg,#fffcf552,#fffcf500),var(--paper-strong);border:1px solid #6d18212e;border-radius:0;box-shadow:inset 0 0 0 1px #c3a05d2e,var(--shadow-soft)}html[data-theme=manuscript] .system-detail-card{overflow:hidden;padding:2rem;position:relative}html[data-theme=manuscript] .system-detail-card:before{color:var(--secondary-text-color);content:none;font-family:Source Sans\ 3,sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.16em;position:absolute;right:1.15rem;text-transform:uppercase;top:1rem}html[data-theme=manuscript] .system-detail-summary{line-height:1.92}html[data-theme=manuscript] .system-detail-summary:first-letter{color:var(--accent-cyan);float:left;font-family:Cinzel Decorative,serif;font-size:2.8rem;line-height:.9;margin:0 .35rem 0 0}html[data-theme=manuscript] .system-detail-stack{line-height:1.82}html[data-theme=manuscript] .system-detail-stack strong{color:var(--primary-text-color)}html[data-theme=manuscript] .system-log{grid-gap:.7rem;display:grid;gap:.7rem}html[data-theme=manuscript] .system-log-line{gap:.65rem;line-height:1.76}html[data-theme=manuscript] .system-log-prompt{color:var(--accent-gold);font-weight:700}html[data-theme=manuscript] .featured-project-actions{gap:.85rem;margin-top:1.5rem}html[data-theme=manuscript] .featured-project-button,html[data-theme=manuscript] .project-live-link,html[data-theme=manuscript] .theme-lab-button,html[data-theme=manuscript] .timeline-read-more{border-radius:0;transition:transform .22s ease,background .22s ease,color .22s ease,border-color .22s ease}html[data-theme=manuscript] .featured-project-button,html[data-theme=manuscript] .project-live-link{font-family:Source Sans\ 3,sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.16em;padding:.92rem 1.15rem;text-transform:uppercase}html[data-theme=manuscript] .featured-project-button.primary,html[data-theme=manuscript] .project-live-link,html[data-theme=manuscript] .theme-lab-button.primary{background:var(--accent-cyan);border:1px solid var(--accent-cyan);color:var(--button-inverse-text)}html[data-theme=manuscript] .featured-project-button.secondary{background:#fffaf185;border:1px solid #6d182138;color:var(--primary-text-color)}html[data-theme=manuscript] .featured-project-button:hover,html[data-theme=manuscript] .project-live-link:hover,html[data-theme=manuscript] .theme-lab-button:hover{transform:translateY(-2px)}html[data-theme=manuscript] .featured-project-button.secondary:hover{border-color:var(--accent-gold);color:var(--accent-cyan)}html[data-theme=manuscript] .timeline-container{margin:4.8rem auto}html[data-theme=manuscript] .about-text h2,html[data-theme=manuscript] .skills-title,html[data-theme=manuscript] .timeline-title{font-size:clamp(2.9rem,5vw,4.6rem);margin-bottom:2.6rem;text-align:center}html[data-theme=manuscript] .timeline{counter-reset:folio;padding-top:.4rem;position:relative}html[data-theme=manuscript] .timeline-line{background:linear-gradient(180deg,#0000,#6d18213d,#c3a05d80,#6d18213d,#0000);width:2px}html[data-theme=manuscript] .timeline-item{counter-increment:folio}html[data-theme=manuscript] .timeline-dot{background:var(--paper-strong);border:2px solid var(--accent-cyan);border-radius:0;box-shadow:0 0 0 4px #fff7e75c;height:18px;top:1.2rem;transform:rotate(45deg);width:18px}html[data-theme=manuscript] .timeline-item:hover .timeline-dot{background:var(--accent-gold);transform:rotate(45deg) scale(1.08)}html[data-theme=manuscript] .timeline-content{background:linear-gradient(180deg,#fffcf557,#fffcf500),var(--paper-color);border:1px solid #6d18212e;border-radius:0;box-shadow:inset 0 0 0 1px #c3a05d2e,var(--shadow-soft);overflow:hidden;position:relative}html[data-theme=manuscript] .timeline-content:before{color:var(--accent-cyan);content:"Folio " counter(folio,upper-roman);font-family:Source Sans\ 3,sans-serif;font-size:.72rem;font-weight:700;left:1.4rem;letter-spacing:.18em;position:absolute;text-transform:uppercase;top:1rem}html[data-theme=manuscript] .timeline-content:after{background:linear-gradient(90deg,var(--accent-cyan),var(--accent-gold),#0000);content:"";height:4px;inset:auto 0 0 0;opacity:.74;position:absolute}html[data-theme=manuscript] .timeline-item:hover .timeline-content{box-shadow:inset 0 0 0 1px #c3a05d3d,0 24px 54px #2d1d121f;transform:translateY(-5px)}html[data-theme=manuscript] .timeline-date,html[data-theme=manuscript] .timeline-project-preview,html[data-theme=manuscript] .timeline-project-title{position:relative;z-index:1}html[data-theme=manuscript] .timeline-date{color:var(--accent-cyan);display:inline-block;font-family:Source Sans\ 3,sans-serif;font-size:.76rem;font-weight:700;letter-spacing:.16em;margin:2.15rem 0 .6rem;text-transform:uppercase}html[data-theme=manuscript] .timeline-project-title{font-family:Cinzel Decorative,serif;font-size:1.9rem;line-height:1;margin-bottom:.75rem}html[data-theme=manuscript] .timeline-project-preview{font-size:.95rem;line-height:1.84}html[data-theme=manuscript] .timeline-read-more{color:var(--accent-gold);font-family:Source Sans\ 3,sans-serif;font-weight:700;letter-spacing:.12em;margin-top:.9rem;text-transform:uppercase}html[data-theme=manuscript] .about-content{align-items:center;gap:2.8rem}html[data-theme=manuscript] .about-text{padding:2.2rem}html[data-theme=manuscript] .about-text h2{margin-bottom:1.15rem;text-align:left}html[data-theme=manuscript] .about-text p{line-height:1.92;margin-bottom:1rem}html[data-theme=manuscript] .about-text p:first-of-type:first-letter{color:var(--accent-cyan);float:left;font-family:Cinzel Decorative,serif;font-size:4rem;line-height:.9;margin:.08rem .38rem 0 0}html[data-theme=manuscript] .about-image{max-width:340px;position:relative}html[data-theme=manuscript] .about-image:after,html[data-theme=manuscript] .about-image:before{content:"";inset:0;pointer-events:none;position:absolute}html[data-theme=manuscript] .about-image:before{border:1px solid #6d182138;inset:-14px 18px 18px -14px}html[data-theme=manuscript] .about-image:after{border:1px solid #c3a05d47;inset:18px -14px -14px 18px}html[data-theme=manuscript] .about-image img{background:var(--paper-strong);border:1px solid #6d18212e;border-radius:0;box-shadow:none;filter:sepia(.18) contrast(1.04);padding:.7rem;position:relative;width:100%;z-index:1}html[data-theme=manuscript] .about-image:hover img{transform:translateY(-4px)}html[data-theme=manuscript] .skills-container{margin:4.8rem auto}html[data-theme=manuscript] .skills-grid{gap:1.4rem}html[data-theme=manuscript] .skill-category{overflow:hidden;padding:1.8rem;position:relative}html[data-theme=manuscript] .skill-category:before{color:#6d182129;font-family:Cinzel Decorative,serif;font-size:3.2rem;line-height:1;position:absolute;right:1rem;top:1rem}html[data-theme=manuscript] .skill-category:first-child:before{content:"I"}html[data-theme=manuscript] .skill-category:nth-child(2):before{content:"II"}html[data-theme=manuscript] .skill-category:nth-child(3):before{content:"III"}html[data-theme=manuscript] .skill-category .border-svg{display:none}html[data-theme=manuscript] .skill-category h3{font-size:1.95rem;margin-bottom:1rem;position:relative;z-index:1}html[data-theme=manuscript] .skill-category ul{grid-gap:.45rem;display:grid;gap:.45rem;grid-template-columns:1fr;position:relative;z-index:1}html[data-theme=manuscript] .skill-category li{background:#0000;border:none;border-radius:0;color:var(--secondary-text-color);font-size:.95rem;padding:.55rem 0 .55rem 1.2rem;position:relative}html[data-theme=manuscript] .skill-category li:before{color:var(--accent-gold);content:"+";font-size:.82rem;left:0;position:absolute;top:.55rem}html[data-theme=manuscript] .skill-category:hover{transform:translateY(-5px)}html[data-theme=manuscript] .terminal-container{max-width:980px}html[data-theme=manuscript] .terminal-header{background:linear-gradient(90deg,#6d182114,#c3a05d0f);border-bottom:1px solid #6d18212e;padding:1rem}html[data-theme=manuscript] .terminal-header-dot{border-radius:0}html[data-theme=manuscript] .terminal-header-dot.red{background:var(--accent-cyan)}html[data-theme=manuscript] .terminal-header-dot.yellow{background:var(--accent-gold)}html[data-theme=manuscript] .terminal-header-dot.green{background:#5f4b31}html[data-theme=manuscript] .terminal-header span{color:var(--secondary-text-color);font-family:Source Sans\ 3,sans-serif;font-size:.76rem;font-weight:700;letter-spacing:.18em}html[data-theme=manuscript] .terminal-body{background:linear-gradient(180deg,#fffcf52e,#fffcf500),repeating-linear-gradient(0deg,#0000,#0000 33px,rgba(109,24,33,.035) 0,rgba(109,24,33,.035) 34px)}html[data-theme=manuscript] .contact-item,html[data-theme=manuscript] .terminal-body,html[data-theme=manuscript] .terminal-input,html[data-theme=manuscript] .terminal-line{font-family:Source Sans\ 3,sans-serif}html[data-theme=manuscript] .contact-item a,html[data-theme=manuscript] .terminal-line.link a{color:var(--accent-cyan)}html[data-theme=manuscript] .contact-item a:hover,html[data-theme=manuscript] .terminal-line.link a:hover{color:var(--accent-gold)}html[data-theme=manuscript] .prompt-text{color:var(--accent-cyan)}html[data-theme=manuscript] .project-page-container{padding:2.4rem 0 4.2rem;width:min(94%,1180px)}html[data-theme=manuscript] .project-header{border-bottom:1px solid #6d18212e;margin-bottom:2.1rem;padding-bottom:2rem}html[data-theme=manuscript] .project-header h1{font-size:clamp(3.2rem,7vw,5.6rem);line-height:.94;max-width:12ch}html[data-theme=manuscript] .project-header span{letter-spacing:.16em}html[data-theme=manuscript] .back-link,html[data-theme=manuscript] .project-header span{color:var(--accent-cyan);font-family:Source Sans\ 3,sans-serif;font-size:.76rem;font-weight:700;text-transform:uppercase}html[data-theme=manuscript] .back-link{letter-spacing:.14em}html[data-theme=manuscript] .project-body.side-by-side{gap:2rem}html[data-theme=manuscript] .main-image-container{max-width:760px;width:100%}html[data-theme=manuscript] .main-image-container:before{border:1px solid #6d18212e;content:"";inset:-14px 18px 18px -14px;position:absolute;z-index:-1}html[data-theme=manuscript] .main-image-container:after{color:var(--accent-cyan);content:"Illustrated Figure";font-family:Source Sans\ 3,sans-serif;font-size:.72rem;font-weight:700;left:0;letter-spacing:.18em;position:absolute;text-transform:uppercase;top:-1.6rem}html[data-theme=manuscript] .main-image-container.placeholder-media:after{display:none}html[data-theme=manuscript] .main-image,html[data-theme=manuscript] .main-video{background:var(--paper-strong);border:1px solid #6d18212e;border-radius:0;box-shadow:none}html[data-theme=manuscript] .main-image-container:hover .main-image,html[data-theme=manuscript] .main-image-container:hover .main-video{transform:translateY(-4px)}html[data-theme=manuscript] .thumbnail-image{background:var(--paper-strong);border:1px solid #6d18212e;border-radius:0}html[data-theme=manuscript] .thumbnail-image:hover{border-color:var(--accent-gold)}html[data-theme=manuscript] .thumbnail-image.active{border-color:var(--accent-cyan);box-shadow:none}html[data-theme=manuscript] .project-media-placeholder{min-height:420px}html[data-theme=manuscript] .project-details h3,html[data-theme=manuscript] .project-media-placeholder h2{font-size:2.2rem;line-height:.98}html[data-theme=manuscript] .project-details p,html[data-theme=manuscript] .project-media-placeholder p{line-height:1.92}html[data-theme=manuscript] .footer{background:#0000;border-top:1px solid #6d182129;color:var(--secondary-text-color)}html[data-theme=manuscript] .theme-lab-trigger{min-width:180px;padding:.95rem 1rem}html[data-theme=manuscript] .theme-lab-trigger strong{font-size:1.42rem;margin-top:.36rem}html[data-theme=manuscript] .theme-lab-drawer{padding:1.35rem;width:min(380px,calc(100vw - 2rem))}html[data-theme=manuscript] .theme-lab-drawer h3{font-size:1.85rem;line-height:1;margin:.45rem 1.8rem 0 0}html[data-theme=manuscript] .theme-lab-note{line-height:1.8;margin-top:.9rem}html[data-theme=manuscript] .theme-lab-close:hover{color:var(--accent-cyan)}@keyframes manuscript-rise{0%{opacity:0;transform:translateY(105vh) scale(.8)}18%{opacity:.34}to{opacity:0;transform:translateY(-14vh) scale(1.2)}}@keyframes manuscript-trail-fade{0%{opacity:.22;transform:translate(-50%,-50%) rotate(45deg) scale(.9)}to{opacity:0;transform:translate(-50%,-50%) rotate(90deg) scale(1.9)}}@media (max-width:768px){html[data-theme=manuscript] .navbar{padding-top:.8rem}html[data-theme=manuscript] .navbar-inner{padding:.85rem 0 .9rem;position:relative;width:95%}html[data-theme=manuscript] .nav-links{display:none}html[data-theme=manuscript] .nav-links.active{background:var(--paper-strong);border:1px solid #6d18212e;border-radius:0;box-shadow:none;display:flex;flex-direction:column;gap:0;left:0;padding:0;position:absolute;right:0;top:calc(100% + .8rem)}html[data-theme=manuscript] .nav-links.active a{border-bottom:1px solid #6d18211f;padding:1rem .2rem;text-align:left;width:100%}html[data-theme=manuscript] .nav-links.active a:last-child{border-bottom:none}html[data-theme=manuscript] .nav-links.active a:after,html[data-theme=manuscript] .nav-links.active a:before{display:none}html[data-theme=manuscript] .hamburger-menu{background:#0000;border:none;display:flex;flex-direction:column;height:24px;justify-content:space-around;padding:0;width:30px}html[data-theme=manuscript] .hamburger-bar{background:var(--primary-text-color);border-radius:0;height:2px;transition:all .3s ease-in-out;width:100%}html[data-theme=manuscript] .hamburger-menu.active .hamburger-bar:first-child{transform:translateY(8px) rotate(45deg)}html[data-theme=manuscript] .hamburger-menu.active .hamburger-bar:nth-child(2){opacity:0}html[data-theme=manuscript] .hamburger-menu.active .hamburger-bar:nth-child(3){transform:translateY(-8px) rotate(-45deg)}html[data-theme=manuscript] .hero{min-height:auto;padding:2rem 0 2.4rem}html[data-theme=manuscript] .hero-content{gap:1.4rem;grid-template-columns:1fr;min-height:auto;padding:3rem 1.25rem 2rem;width:95%}html[data-theme=manuscript] .hero-content h1{font-size:clamp(3rem,14vw,4.9rem);max-width:none}html[data-theme=manuscript] .hero-content p{margin:0;max-width:none}html[data-theme=manuscript] .about-text,html[data-theme=manuscript] .contact-tile,html[data-theme=manuscript] .featured-project-shell,html[data-theme=manuscript] .project-details,html[data-theme=manuscript] .project-media-placeholder,html[data-theme=manuscript] .skill-category,html[data-theme=manuscript] .system-detail-card,html[data-theme=manuscript] .terminal-container,html[data-theme=manuscript] .theme-lab-drawer,html[data-theme=manuscript] .theme-lab-trigger{padding:1.35rem}html[data-theme=manuscript] .about-text h2,html[data-theme=manuscript] .featured-project-header h2,html[data-theme=manuscript] .skills-title,html[data-theme=manuscript] .timeline-title{font-size:clamp(2.25rem,11vw,3.3rem)}html[data-theme=manuscript] .system-selector-button{text-align:left;width:100%}html[data-theme=manuscript] .timeline-line{left:18px;transform:translateX(0)}html[data-theme=manuscript] .timeline-item,html[data-theme=manuscript] .timeline-item:nth-child(2n){left:0;padding-left:3.5rem;padding-right:0;text-align:left;width:100%}html[data-theme=manuscript] .timeline-dot,html[data-theme=manuscript] .timeline-item:nth-child(2n) .timeline-dot,html[data-theme=manuscript] .timeline-item:nth-child(odd) .timeline-dot{left:9px;right:auto}html[data-theme=manuscript] .about-content{gap:1.8rem;grid-template-columns:1fr}html[data-theme=manuscript] .about-image{max-width:270px;order:1}html[data-theme=manuscript] .about-text{order:2}html[data-theme=manuscript] .project-body.side-by-side{flex-direction:column}html[data-theme=manuscript] .project-body.side-by-side .project-details,html[data-theme=manuscript] .project-body.side-by-side .project-gallery{max-width:100%}html[data-theme=manuscript] .featured-project-actions{flex-direction:column}html[data-theme=manuscript] .theme-lab{align-items:stretch;bottom:.8rem;left:.8rem;right:.8rem}html[data-theme=manuscript] .theme-lab-drawer,html[data-theme=manuscript] .theme-lab-trigger{width:100%}}@media (min-width:769px){html[data-theme=manuscript] .hamburger-menu{display:none}}
/*# sourceMappingURL=main.5aa046a7.css.map*/