@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap";:root{--bg: #ececec;--ink: #1b1b1b;--muted: #5a5a5a;--card: #f7f5f2;--stroke: rgba(27, 27, 27, .12)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}html{scroll-behavior:smooth}body{font-family:Space Grotesk,sans-serif;background:var(--bg);color:var(--ink);scroll-snap-type:none}.cursor-trail{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.trail-dot{position:absolute;top:0;left:0;width:12px;height:12px;border-radius:999px;transform:translate3d(-100px,-100px,0);background:radial-gradient(circle at 30% 30%,#99dbb099,#9fd2ff33);mix-blend-mode:multiply;opacity:.22;filter:blur(.8px);transition:opacity .3s ease}.trail-1,.trail-2,.trail-3{opacity:.14;width:16px;height:16px}.trail-4,.trail-5{opacity:.09;width:21px;height:21px}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg width='200' height='200' viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='.08'/%3E%3C/svg%3E");mix-blend-mode:multiply;z-index:1}.hero-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 25%,rgba(153,219,176,.28),transparent 50%),radial-gradient(circle at 70% 30%,rgba(159,210,255,.28),transparent 55%),radial-gradient(circle at 50% 75%,rgba(230,214,190,.25),transparent 55%),#ececec}.page{position:relative;min-height:100vh;width:100%}.section{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease;position:relative}.section.is-visible{opacity:1;transform:translateY(0)}.scroll-rail{position:fixed;right:2rem;top:25%;height:50%;width:4px;background:#1b1b1b1a;border-radius:999px;z-index:3}.scroll-bar{width:100%;background:linear-gradient(180deg,#ffe8ef,#d6f2ff,#e6f9eb);border-radius:999px;height:8%;transition:height .2s ease}.hero{position:relative;min-height:100svh;width:100vw;overflow:visible;scroll-snap-align:start;scroll-snap-stop:always;background:radial-gradient(circle at 62% 42%,rgba(183,214,220,.18),transparent 18%),radial-gradient(circle at 66% 52%,rgba(184,216,207,.1),transparent 22%),radial-gradient(circle at 18% 24%,rgba(242,236,224,.74),transparent 28%),linear-gradient(115deg,#f2ece0f7,#ece8e2f2,#e4edeff2 68%,#eaf0eef5)}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 61% 44%,rgba(199,221,227,.12),transparent 14%),radial-gradient(circle at 66% 39%,rgba(255,248,241,.22),transparent 15%),linear-gradient(180deg,#ffffff14,#fff0);z-index:0}.hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(circle at 50% 50%,transparent 58%,rgba(207,218,220,.04) 100%),radial-gradient(circle at 63% 48%,rgba(255,255,255,.05),transparent 24%);z-index:0}@keyframes suspended-drift{0%,to{transform:translateZ(0)}50%{transform:translate3d(0,-8px,0)}}@keyframes current-pulse{0%,to{opacity:.92}50%{opacity:1}}.hero-canvas{position:absolute!important;top:0;right:0;bottom:-24vh;left:0;z-index:1}.nav{position:absolute;top:2.2rem;left:2.6rem;right:2.6rem;display:flex;justify-content:flex-end;align-items:center;z-index:2;gap:2rem}.nav-links{display:flex;align-items:center;gap:1.2rem;font-size:.95rem}.nav-links a{text-decoration:none;color:var(--ink)}.nav-links a.pill{color:#f5f5f5}.nav-links a.pill.pill-projects{color:#1b1b1b}.pill{border:none;padding:.5rem 1.1rem;border-radius:999px;background:#1b1b1b;color:#f5f5f5;font-size:.9rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.pill-projects{background:#88bcd533;color:#1b1b1b;border:1px solid rgba(136,188,213,.34)}.status-panel{display:grid;grid-template-columns:1fr;gap:.14rem;align-items:start;padding:0;border-radius:0;background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;min-width:0;position:relative;overflow:hidden}.status-panel:before{content:none}.status-label{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:#5e849fc7;font-weight:600}.status-time{font-size:1.12rem;font-weight:600;letter-spacing:-.02em;color:#324452f0}.status-weather{display:inline-flex;align-items:center;gap:.32rem;font-size:.7rem;line-height:1.2;color:#66838cc7;text-transform:uppercase;letter-spacing:.16em;font-weight:600;margin-top:.18rem}.status-weather-code,.status-weather-temp{white-space:nowrap}.status-divider{color:#6f96a16b}.status-weather-detail{display:inline-flex;align-items:center;gap:.38rem;margin-top:.08rem;font-size:.84rem;line-height:1.25;color:#586e78d1}.weather-icon{display:inline-flex;font-size:.76rem;color:#8bc1b6e6}.hero-status{position:absolute;top:2.35rem;left:3.2rem;z-index:2;cursor:default;animation:none;max-width:220px}.hero-status .status-panel>*{position:relative;z-index:1}.left-rail{position:absolute;left:3rem;top:50%;transform:translateY(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:1.2rem}.socials{display:flex;flex-direction:column;gap:1.2rem;font-size:1.1rem;color:#1b1b1b}.social-link{width:36px;height:36px;border-radius:12px;border:1px solid var(--stroke);background:#fff;display:grid;place-items:center;color:#1b1b1b;transition:transform .2s ease,box-shadow .2s ease}.social-link:hover{transform:translateY(-2px);box-shadow:0 8px 18px #0000001f}.hero-text{position:absolute;top:43.5%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:2;pointer-events:none}.greeting{font-size:.95rem;font-weight:500;letter-spacing:.04em;color:#5b5b5b;margin:0 auto .8rem}.hero-text h1{font-size:clamp(2.6rem,5vw,4.5rem);font-weight:500;line-height:1.2;letter-spacing:-.03em;max-width:13.4ch;margin:0 auto}.right-tabs{position:absolute;right:2.5rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.1rem;z-index:2}.tab-link{text-decoration:none;color:#3a3a3a9e;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg);padding:.2rem .12rem;border-radius:999px;border:1px solid transparent;transition:color .2s ease,transform .2s ease,opacity .2s ease;opacity:.82}.tab-link-accent{color:#c98c5cf5;opacity:.96}.tab-link-accent:hover{color:#8f5a52fa}.tab-link:hover{color:var(--ink);opacity:1;transform:rotate(180deg) translateY(-2px) rotate(3deg)}.scroll-arrow{--cue-progress: 0;width:28px;height:28px;position:absolute;bottom:1.65rem;left:50%;transform:translate(-50%);border-radius:50%;border:1.5px solid rgba(201,140,92,.58);display:grid;place-items:center;color:#8f5a52fa;text-decoration:none;animation:arrow-bounce 2.4s ease-in-out infinite;z-index:2;box-shadow:0 0 0 1px #ffffff38,0 0 calc(18px + 10px * var(--cue-progress)) rgba(216,176,110,calc(.26 + .16 * var(--cue-progress))),0 0 calc(30px + 18px * var(--cue-progress)) rgba(201,140,92,calc(.14 + .14 * var(--cue-progress)));animation:arrow-bounce 2.4s ease-in-out infinite,current-pulse 4.8s ease-in-out infinite}.scroll-arrow:before{content:"";position:absolute;top:-18px;right:-18px;bottom:-18px;left:-18px;border-radius:999px;border:1px solid rgba(201,140,92,calc(.16 + .22 * var(--cue-progress)));opacity:calc(.12 + .5 * var(--cue-progress));transform:scale(calc(.82 + .28 * var(--cue-progress)));transition:opacity .18s ease,transform .18s ease,border-color .18s ease}@keyframes arrow-bounce{0%,to{transform:translate(-50%)}50%{transform:translate(-50%,6px)}}.status-pill{position:absolute;bottom:2rem;right:2rem;padding:.55rem 1.2rem;border-radius:999px;color:#1b1b1b;font-weight:600;font-size:.95rem;background:transparent;border:none;box-shadow:none;z-index:2}.skills{background:transparent;padding:5rem 7vw 6rem;border-top:none;border-bottom:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skills:before,.side-projects:before,.work:before,.contact-footer:before,.assistant:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.skills:after,.side-projects:after,.work:after,.contact-footer:after,.assistant:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.skills>*,.side-projects>*,.work>*,.contact-footer>*,.assistant>*{position:relative;z-index:1}.assistant{background:transparent;padding:2.6rem 7vw 6.2rem;position:relative;overflow:hidden;margin-top:0;z-index:2;scroll-snap-align:start;scroll-snap-stop:always;min-height:100svh;box-sizing:border-box;display:flex;flex-direction:column;justify-content:space-between;gap:1.6rem;height:100svh}.assistant:before{background:none}.assistant:after{background:none}.assistant-head{max-width:760px;margin-bottom:.2rem}.assistant-layout{display:flex;flex-direction:column;margin-top:0;flex:1 1 auto;min-height:0;height:100%}.assistant-shell{--cue-progress: 0;border:1px solid rgba(27,27,27,.06);background:#ffffff8f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 12px 22px #14121009;transform:translateY(calc((1 - var(--cue-progress)) * 10px));transition:transform .18s ease,box-shadow .18s ease,background-color .18s ease,border-color .18s ease}.assistant-label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.assistant-shell{border-radius:2rem;padding:1.2rem;display:flex;flex-direction:column;gap:1rem;width:100%;position:relative;overflow:hidden;min-height:0;height:100%;max-height:none;flex:1 1 auto}.assistant-shell:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#ffffff05,#ffffff03 10%,#fff0 18%),radial-gradient(circle at 18% 18%,rgba(242,236,224,.12),transparent 36%),radial-gradient(circle at 86% 20%,rgba(199,221,227,.08),transparent 32%);z-index:0}.assistant-shell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(circle at 14% 20%,rgba(114,138,151,.045) 0 1px,transparent 2px),radial-gradient(circle at 26% 74%,rgba(114,138,151,.035) 0 .9px,transparent 2px),radial-gradient(circle at 66% 24%,rgba(114,138,151,.04) 0 1px,transparent 2.2px),radial-gradient(circle at 82% 62%,rgba(114,138,151,.035) 0 .9px,transparent 1.8px),radial-gradient(circle at 48% 44%,rgba(143,201,187,.04) 0 1.8px,transparent 5.5px),radial-gradient(circle at 76% 34%,rgba(125,178,200,.04) 0 1.7px,transparent 5px),radial-gradient(circle at 38% 68%,rgba(209,176,110,.035) 0 1.5px,transparent 4.8px),radial-gradient(circle at 72% 56%,rgba(201,140,92,.03) 0 1.3px,transparent 4.2px);background-size:420px 420px,520px 520px,600px 600px,700px 700px,560px 560px,620px 620px,680px 680px,760px 760px;opacity:.018;z-index:0}.assistant-messages{display:grid;align-content:start;gap:.9rem;flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-right:.3rem;scrollbar-width:thin;scrollbar-color:rgba(27,27,27,.12) transparent;position:relative;z-index:1}.assistant-messages::-webkit-scrollbar{width:8px}.assistant-messages::-webkit-scrollbar-thumb{border-radius:999px;background:#1b1b1b1f}.assistant-message{display:grid;gap:.42rem;padding:.95rem 1rem;border-radius:1.2rem;border:1px solid rgba(27,27,27,.08);min-width:0}.assistant-empty-state{display:grid;gap:.55rem;align-content:start;max-width:44rem;padding:.25rem 0 .1rem}.assistant-empty-kicker{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}.assistant-empty-copy{font-size:.94rem;line-height:1.6;color:#c98c5ceb;max-width:34rem}.assistant-message-ai{justify-self:start;max-width:min(100%,46rem);background:#ffffffb8;border-color:#1b1b1b0f}.assistant-message-user{justify-self:end;max-width:min(100%,20rem);min-width:8.75rem;background:#e8f8ece0;border-color:#1c6e531a}.assistant-message-role{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);opacity:.62;font-weight:600}.assistant-message-body{display:grid;gap:.55rem;color:#1b1b1be0;line-height:1.66;min-width:0;overflow-wrap:anywhere;word-break:break-word;font-size:.97rem}.assistant-suggestions{display:flex;flex-wrap:wrap;gap:.65rem;margin-top:1rem}.assistant-suggestion{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(97,89,82,.16);background:#ffffff94;color:#4d3e38d6;border-radius:999px;padding:.55rem .9rem;font:inherit;font-size:.9rem;line-height:1.2;cursor:pointer;transition:border-color .18s ease,background .18s ease,color .18s ease,transform .18s ease}.assistant-suggestion:hover{border-color:#b07d5c4d;background:#f8f2ecc7;color:#5d4132eb;transform:translateY(-1px)}.assistant-suggestion:disabled{cursor:default;opacity:.55;transform:none}.assistant-message-body p{margin:0}.assistant-message-body a{color:inherit;text-decoration-color:#1b1b1b38;text-underline-offset:.14em}.assistant-message-body ul{padding-left:1rem;display:grid;gap:.32rem;margin:0}.assistant-sources{display:grid;gap:.8rem;margin-top:.1rem}.assistant-source-card{display:grid;grid-template-columns:auto minmax(0,1fr);gap:.9rem;padding:.88rem;border-radius:1rem;background:#faf9f6b8;border:1px solid rgba(27,27,27,.06)}.assistant-source-media{width:84px;height:64px;border-radius:.85rem;overflow:hidden;background:#ffffffb8;border:1px solid rgba(27,27,27,.08)}.assistant-source-media img{width:100%;height:100%;object-fit:cover;display:block}.assistant-source-copy{display:grid;gap:.28rem;min-width:0}.assistant-source-type{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#5a5a5aa8}.assistant-source-copy h4{font-size:.96rem;line-height:1.35;color:var(--ink)}.assistant-source-summary{color:#1b1b1bb8;font-size:.84rem;line-height:1.55}.assistant-source-link{justify-self:start;margin-top:.14rem;text-decoration:none;color:#1b1b1b;font-size:.82rem;font-weight:600}.assistant-source-link:hover{opacity:.72}.assistant-message-loading{min-width:180px}.assistant-loading-dots{display:inline-flex;align-items:center;gap:.42rem}.assistant-loading-dots span{width:7px;height:7px;border-radius:999px;background:#5a5a5a6b;animation:assistant-dot-pulse 1.2s ease-in-out infinite}.assistant-loading-dots span:nth-child(2){animation-delay:.15s}.assistant-loading-dots span:nth-child(3){animation-delay:.3s}@keyframes assistant-dot-pulse{0%,to{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}.assistant-composer{display:grid;gap:.8rem;padding-top:.2rem;position:relative;z-index:1;margin-top:auto;flex:0 0 auto}.assistant-input{width:100%;resize:vertical;min-height:120px;border-radius:1.2rem;border:1px solid rgba(27,27,27,.08);background:#ffffffd6;color:var(--ink);font:inherit;line-height:1.6;padding:1rem 1.05rem;outline:none;transition:border-color .22s ease,box-shadow .22s ease,background-color .22s ease}.assistant-input::placeholder{color:#5a5a5a9e}.assistant-input:focus{border-color:#9fd2ff47;box-shadow:0 0 0 1px #9fd2ff1f;background:#fffffff5}.assistant-composer-footer{display:flex;justify-content:flex-end;gap:1rem;align-items:flex-end;flex-wrap:wrap}.assistant-hint{color:var(--muted);font-size:.84rem;line-height:1.5;max-width:34rem}.assistant-send{border:1px solid rgba(27,27,27,.08);background:#1b1b1b;color:#f5f5f5;font:inherit;font-weight:600;padding:.82rem 1.1rem;min-width:126px;border-radius:999px;cursor:pointer;transition:transform .22s ease,background-color .22s ease,border-color .22s ease,opacity .22s ease}.assistant-send:hover:not(:disabled){transform:translateY(-1px);background:#111;border-color:#1b1b1b24}.assistant-send:disabled{opacity:.52;cursor:not-allowed}.assistant-error{color:#a0655e;font-size:.85rem}.assistant-contact-links{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:flex-end}.assistant-contact-links-footer{margin-top:1rem;justify-content:flex-start}.assistant-contact-link{border:1px solid rgba(27,27,27,.08);background:#ffffffc7;color:var(--ink);text-decoration:none;padding:.68rem .88rem;border-radius:1rem;font:inherit;font-size:.86rem;line-height:1.45;display:inline-flex;align-items:center;gap:.5rem;transition:transform .22s ease,background-color .22s ease,border-color .22s ease,box-shadow .22s ease}.assistant-contact-link:hover{transform:translateY(-1px);background:#fffffff0;border-color:#1b1b1b1f;box-shadow:0 10px 16px #14121014}.skills:before{background:radial-gradient(circle at 18% 10%,rgba(82,97,111,.12),transparent 38%),radial-gradient(circle at 84% 18%,rgba(86,128,145,.08),transparent 42%),linear-gradient(180deg,#0b141cad,#0b141c42)}.skills:after{background:radial-gradient(circle at 50% -8%,rgba(36,58,72,.1),transparent 42%),radial-gradient(circle at 50% 108%,rgba(28,47,60,.08),transparent 44%)}.note-card{max-width:720px;padding:2.5rem;border-radius:1.2rem;background:#ffffffa3;border:1px solid rgba(27,27,27,.08);box-shadow:0 18px 30px #14121012;position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.note-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(180deg,rgba(27,27,27,.03) 0px,rgba(27,27,27,.03) 1px,transparent 1px,transparent 26px),radial-gradient(circle at 15% 10%,rgba(79,141,126,.18),transparent 60%),radial-gradient(circle at 90% 20%,rgba(94,132,159,.18),transparent 60%);z-index:0;opacity:.9}.note-card:after{content:"";position:absolute;top:10px;right:14px;width:52px;height:18px;background:#5e849f40;border:1px solid rgba(27,27,27,.08);border-radius:6px;transform:rotate(-6deg);z-index:0}.note-card:hover{transform:translateY(-3px) rotate(-.4deg);box-shadow:0 26px 46px #1412101a}.note-card>*{position:relative;z-index:1}.note-card h2{margin-top:.4rem}.note-card h2:after{content:"";display:block;width:120px;height:2px;border-radius:999px;margin-top:.6rem;background:linear-gradient(90deg,#2d261ab3,#2d261a1a)}.note-body{margin-top:1rem;color:#5a5a5a;font-size:1rem;line-height:1.7}.note-meta{margin-top:1.4rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.2em;color:var(--muted)}.hero-note{position:absolute;left:3.2rem;bottom:6.2rem;max-width:332px;padding:1.3rem 1.45rem 1.2rem 1.5rem;border-radius:16px;background:#fcfaf5ad;border:1px solid rgba(27,27,27,.08);box-shadow:0 10px 20px #1412100d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:2;cursor:default;animation:suspended-drift 11s ease-in-out infinite}.hero-note:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(180deg,rgba(27,27,27,.014) 0px,rgba(27,27,27,.014) 1px,transparent 1px,transparent 30px),radial-gradient(circle at 18% 14%,rgba(92,151,136,.06),transparent 54%),radial-gradient(circle at 88% 18%,rgba(94,132,159,.06),transparent 56%);opacity:.78;pointer-events:none;border-radius:16px}.hero-note .kicker{margin-bottom:.42rem;font-size:.61rem;letter-spacing:.28em;color:#6c6c6cb8;font-weight:600}.hero-note h3{margin:0;font-size:1.12rem;line-height:1.28;letter-spacing:-.01em}.hero-note .note-body{margin-top:.78rem;color:#4c4c4cdb;line-height:1.56;font-size:.93rem}.hero-note .note-meta{margin-top:1.15rem;font-size:.63rem;letter-spacing:.22em;text-transform:uppercase;color:#8ca1aa8a}.hero-note:after{content:"";position:absolute;left:1.05rem;top:1.15rem;bottom:1.15rem;width:1px;height:auto;background:linear-gradient(180deg,#3f3f3f24,#3f3f3f0a 26%,#3f3f3f1a);border-radius:999px;box-shadow:none}.hero-note .kicker{font-size:.6rem;letter-spacing:.32em}.hero-note h3{margin-top:.35rem;font-size:1rem}.hero-note .note-body{font-size:.82rem;line-height:1.5}.hero-note .note-meta{font-size:.6rem}.hero-note>*{position:relative;z-index:1}.hero-note .kicker,.hero-note h3,.hero-note .note-body,.hero-note .note-meta{padding-left:.45rem}.hero-note h3{margin-top:.4rem;font-size:1.1rem}.hero-note .note-body{font-size:.86rem}.hero-note .note-meta{font-size:.65rem}@media (max-width: 900px){.hero-note{display:none}}.side-projects{background:transparent;padding:5rem 7vw 6rem;border-top:none;border-bottom:none;position:relative;overflow:hidden}.side-projects:before{background:radial-gradient(circle at top left,rgba(75,89,102,.12),transparent 38%),radial-gradient(circle at top right,rgba(85,125,141,.08),transparent 44%),linear-gradient(180deg,#0b151e7a,#0b151e1f)}.side-projects:after{background:radial-gradient(circle at 50% -10%,rgba(34,55,67,.08),transparent 40%),radial-gradient(circle at 50% 110%,rgba(30,49,61,.08),transparent 42%)}.side-projects .work-head,.side-projects .side-showcase{position:relative;z-index:1}.side-projects .kicker{letter-spacing:.6em;font-size:.7rem;color:#9aafb8b8}.side-showcase{margin-top:2.6rem;display:grid;grid-template-columns:minmax(220px,.65fr) minmax(0,1.35fr);gap:2rem;align-items:stretch}.side-index{display:grid;gap:.9rem;align-content:start;max-height:36rem;overflow-y:auto;padding:.18rem .18rem .18rem .08rem;scrollbar-width:thin;scrollbar-color:rgba(214,233,241,.18) transparent}.side-index::-webkit-scrollbar{width:8px}.side-index::-webkit-scrollbar-track{background:transparent}.side-index::-webkit-scrollbar-thumb{background:#d6e9f124;border-radius:999px}.side-index::-webkit-scrollbar-thumb:hover{background:#d6e9f13d}.side-index-item{display:grid;grid-template-columns:auto 1fr;gap:.9rem;align-items:start;width:100%;text-align:left;padding:1rem 1.05rem;border-radius:1.2rem;border:1px solid rgba(214,233,241,.08);background:#0d1822bd;cursor:pointer;transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,background-color .22s ease}.side-index-item:hover{transform:translateY(-1px);border-color:#d6e9f129;box-shadow:0 8px 16px #00000029}.side-index-item.active{background:#111f2af5;border-color:#68aa943d;box-shadow:0 10px 18px #0000002e}.side-index-number{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#8fa4ad6b;padding-top:.18rem}.side-index-copy{display:grid;gap:.32rem}.side-index-copy strong{font-size:1rem;font-weight:600;color:var(--ink)}.side-index-copy span{color:#adbec69e;line-height:1.5;font-size:.88rem}.side-feature{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;border-radius:2rem;border:1px solid rgba(214,233,241,.08);background:#0c1620c7;padding:1.6rem;box-shadow:0 18px 32px #00000038;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.side-feature-copy{display:grid;align-content:start;gap:1rem}.side-feature-kicker{color:#91a3ac85;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}.side-feature h3{font-size:clamp(2rem,4vw,3.2rem);line-height:.98;max-width:10ch;color:#e6edf1f2;text-shadow:0 0 22px rgba(122,178,200,.04)}.side-feature-summary{font-size:1rem;line-height:1.8;color:#d0dde3;max-width:56ch}.side-feature-note{color:#a9bbc3a8;line-height:1.7;max-width:52ch}.side-feature-list{display:flex;flex-wrap:wrap;gap:.65rem}.side-feature-pill{display:inline-flex;align-items:center;padding:.38rem .7rem;border-radius:.72rem;border:1px solid rgba(214,233,241,.06);background:#d6e9f10d;color:#86b9aa;font-size:.74rem;font-weight:600;letter-spacing:.03em}.side-feature-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:.2rem;justify-content:flex-end}.side-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:.72rem 1.1rem;border-radius:999px;text-decoration:none;font-weight:600;transition:transform .22s ease,box-shadow .22s ease,background-color .22s ease,border-color .22s ease,color .22s ease}.side-button-primary{background:#d6e8ef;color:#091119;box-shadow:0 8px 16px #0000002e}.side-button-primary:hover{transform:translateY(-1px);box-shadow:0 14px 22px #0000003d}.side-button-secondary{color:var(--ink);border:1px solid rgba(214,233,241,.1);background:#d6e9f10a}.side-button-secondary:hover{transform:translateY(-1px);background:#d6e9f10f;border-color:#d6e9f129;box-shadow:0 10px 18px #0000002e}@media (max-width: 900px){body{scroll-snap-type:none}.assistant{min-height:auto;height:auto;display:block}.assistant-layout{min-height:auto;display:block;height:auto}.assistant-shell{min-height:auto;height:auto;max-height:none}.assistant-messages{flex:initial;max-height:none}.side-showcase{grid-template-columns:1fr}.side-feature-actions{justify-content:flex-start}.assistant-composer-footer{flex-direction:row;justify-content:flex-end;align-items:center}.assistant-contact-links{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;justify-content:stretch}.assistant-contact-links-footer{margin-top:.9rem}.assistant-contact-link{justify-content:center;min-height:3rem;padding:.78rem .9rem}.assistant-send{width:auto;align-self:flex-end}.assistant-source-card{grid-template-columns:1fr}.assistant-source-media{width:100%;height:160px}}.skills-columns{margin-top:2.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem}.skills-col{background:#0c1620c2;border:1px solid rgba(214,233,241,.1);border-radius:1.4rem;padding:1.5rem;box-shadow:0 16px 30px #0000003d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.skills-title{text-transform:uppercase;letter-spacing:.22em;font-size:.7rem;color:#96abb5c2;margin-bottom:1rem}.skills-list{display:flex;flex-wrap:wrap;gap:.6rem}.skills-pill{display:inline-flex;align-items:center;justify-content:center;padding:.42rem .72rem;border-radius:.75rem;background:#d6e9f10d;font-size:.77rem;font-weight:600;letter-spacing:.03em;border:1px solid rgba(214,233,241,.08);text-transform:uppercase;color:#d2e0e6}.work{background:transparent;padding:5rem 7vw 6rem}.work:before{background:radial-gradient(circle at 82% 16%,rgba(87,127,144,.08),transparent 40%),radial-gradient(circle at 16% 84%,rgba(74,88,102,.12),transparent 42%),linear-gradient(180deg,#0a121b57,#0a121b1a)}.work:after{background:radial-gradient(circle at 50% -8%,rgba(36,56,70,.08),transparent 40%),radial-gradient(circle at 50% 108%,rgba(29,47,59,.08),transparent 42%)}.work-head{max-width:700px}.kicker{text-transform:uppercase;letter-spacing:.4em;font-size:.7rem;color:#96abb5b8}.work-head h2{margin-top:.8rem;font-size:clamp(2rem,4vw,3.4rem);line-height:1.15;color:#e6edf1f5;text-shadow:0 0 20px rgba(122,178,200,.035)}.work-sub{margin-top:1rem;color:var(--muted)}.work-grid{margin-top:3rem;display:grid;gap:2rem;grid-template-columns:1fr}.work-card{background:#0c1620c7;border:1px solid var(--stroke);border-radius:1.6rem;padding:1.8rem;box-shadow:0 12px 30px #0000003d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);transform:translateY(18px) scale(.98);opacity:0;transition:transform .6s ease,box-shadow .6s ease,opacity .6s ease;transition-delay:var(--delay, 0ms);will-change:transform,box-shadow;position:relative;overflow:hidden}.work-card:before{content:none}.work-card:after{content:none}.work-card>*{position:relative;z-index:1}.work-card:hover{transform:perspective(900px) translateY(-6px) rotateX(1deg) rotateY(-2deg);box-shadow:0 24px 50px #0000004d}.work-title{font-size:1.3rem;font-weight:600;color:#e6edf1f2}.work-role{margin-top:.35rem;color:#b6c8cf;font-weight:500}.work-meta{margin-top:.7rem;display:flex;flex-wrap:wrap;gap:.55rem 1rem;font-size:.83rem;letter-spacing:.03em;text-transform:uppercase;color:#8fa4ad94}.work-body{margin-top:1.15rem;color:#c8d7de;line-height:1.72;max-width:66ch}.work-highlights{margin-top:1.05rem;padding-left:1rem;color:#afc0c8;display:grid;gap:.4rem;font-size:.88rem}.work-tech{margin-top:1.1rem;display:flex;flex-wrap:wrap;gap:.6rem}.tech-chip{border:1px solid rgba(214,233,241,.08);padding:.42rem .72rem;border-radius:.75rem;font-size:.77rem;font-weight:600;letter-spacing:.03em;color:#d2e0e6;background:#d6e9f10d;box-shadow:none}.tech-chip-muted{color:#8fa4ad9e;background:#d6e9f108}.work-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.4rem;color:var(--ink);text-decoration:none;font-weight:600;position:relative;padding-bottom:.1rem;transition:color .3s ease}.work-link:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:2px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.work-link:before{content:"→";margin-right:.5rem;transition:transform .3s ease}.work-link:hover{color:#fff}.work-link:hover:after{transform:scaleX(1)}.work-link:hover:before{transform:translate(4px)}.game{background:transparent;padding:5rem 7vw 6rem;border-top:none}.game-head{max-width:700px}.game-themes{margin-top:1rem;display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.theme-card{border:none;border-radius:999px;padding:.35rem .55rem;background:transparent;display:inline-flex;align-items:center;gap:.45rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);cursor:default;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.theme-card:hover{transform:none;box-shadow:none;border-color:transparent}.theme-card.active{border-color:transparent;box-shadow:none;background:transparent}.theme-swatch{width:18px;height:18px;border-radius:6px;border:none;display:inline-block;background:#eae6df}.theme-swatch[data-theme=paper]{background:linear-gradient(145deg,#faf6f0f2,#e5dfd5cc)}.theme-swatch[data-theme=aura]{background:radial-gradient(circle at 20% 20%,rgba(153,219,176,.55),transparent 60%),radial-gradient(circle at 80% 30%,rgba(159,210,255,.5),transparent 60%),#f0ede9f2}.theme-label{font-weight:500}.mini-game-theme{border-radius:0;padding:0;position:relative;overflow:hidden}.mini-game-theme.paper,.mini-game-theme.aura{background:transparent;border:none}.mini-game-theme.aura .mini-game,.mini-game-theme.paper .mini-game{background:transparent;border-color:transparent;box-shadow:none}.mini-game-wrap{margin-top:2rem;position:relative}.mini-controls{display:flex;justify-content:flex-end;margin-top:.8rem}.mini-game{width:100%;border-radius:1rem;border:1px solid rgba(214,233,241,.1);box-shadow:0 12px 24px #00000038;background:#0c1620b3}.mini-reset{border:none;background:#d6e8ef;color:#091119;padding:.4rem .8rem;border-radius:999px;font-size:.75rem;cursor:pointer}.contact-footer{background:transparent;padding:4.5rem 7vw 6rem;border-top:none}.contact-footer:before{background:radial-gradient(circle at 50% 0%,rgba(92,137,170,.08),transparent 40%),linear-gradient(180deg,#09121b57,#09121b14)}.contact-footer:after{background:radial-gradient(circle at 50% -8%,rgba(34,54,66,.08),transparent 38%),radial-gradient(circle at 50% 108%,rgba(28,45,57,.06),transparent 40%)}.contact-inner{max-width:760px}.contact-links{margin-top:1.5rem;display:flex;flex-wrap:wrap;gap:1rem}.contact-link{display:inline-flex;align-items:center;gap:.6rem;padding:.55rem 1.1rem;border-radius:999px;border:1px solid rgba(214,233,241,.12);background:#d6e9f10f;color:var(--ink);text-decoration:none;font-weight:600;font-size:.85rem;letter-spacing:.02em;transition:transform .25s ease,box-shadow .25s ease;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.contact-link:hover{transform:translateY(-1px);box-shadow:0 10px 20px #00000038}.reveal.is-visible{opacity:1;transform:translateY(0) scale(1)}@media (max-width: 900px){body:before{display:none}.cursor-trail{display:none}.nav{flex-direction:column;gap:1rem}.left-rail,.right-tabs,.scroll-rail{display:none}.nav-links{flex-wrap:wrap;justify-content:center}.status-panel{min-width:unset;width:100%;justify-items:center;text-align:center}.status-weather{justify-content:center}.hero-status,.status-pill{display:none}.work-card{padding:1.4rem;box-shadow:0 8px 16px #0000000f;transform:none}.game{display:none}.side-showcase{gap:1.25rem}.side-index{max-height:none;overflow:visible;padding-right:0}.side-index-item{padding:.9rem .95rem}.side-feature{padding:1.3rem;border-radius:1.45rem}.assistant{margin-top:-2rem;padding-bottom:5rem}}@media (max-width: 600px){.hero-text{width:90%}.hero{min-height:100svh}.greeting{font-size:.88rem}.hero-text h1{font-size:clamp(2.3rem,10vw,3.2rem);line-height:1.12}.skills-columns,.work-grid{grid-template-columns:1fr}.work-meta{gap:.4rem .8rem;font-size:.78rem}.work-body{font-size:.94rem}.work-tech{gap:.5rem}.side-feature-actions{gap:.65rem}.side-button{min-height:42px;padding:.68rem .95rem}.assistant-contact-links{grid-template-columns:1fr}}
