.dock-outer{position:fixed;bottom:0;left:50%;transform:translate(-50%);z-index:100;margin:0 .5rem;display:flex;max-width:100%;align-items:center}.dock-panel{position:absolute;bottom:.75rem;left:50%;transform:translate(-50%);display:flex;align-items:flex-end;width:fit-content;gap:.35rem;border-radius:1rem;background-color:var(--dock-bg);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border:1px solid var(--border-hover);padding:0 .5rem .5rem;box-shadow:0 10px 30px #00000059,0 0 0 1px var(--border) inset;transition:background .45s ease,border-color .45s ease}.dock-item{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background-color:transparent;border:1px solid var(--border);cursor:pointer;outline:none;color:var(--text);transition:color .2s,background .2s,border-color .2s}.dock-item:hover{color:var(--accent);background:var(--accent-subtle);border-color:var(--accent-border)}.dock-icon{display:flex;align-items:center;justify-content:center}.dock-label{position:absolute;top:-1.5rem;left:50%;width:fit-content;white-space:pre;border-radius:.375rem;border:1px solid var(--border-hover);background-color:var(--dock-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:.125rem .5rem;font-size:.7rem;letter-spacing:.04em;color:var(--text);transform:translate(-50%)}.dock-item.dock-sep-item{border:none;background:transparent;cursor:default;pointer-events:none;border-radius:0;flex-shrink:0}.dock-item.dock-sep-item:hover{background:transparent;border:none}@media(max-width:768px){.dock-outer{margin:0}.dock-panel{gap:.15rem;padding:0 .3rem .3rem;border-radius:.85rem;bottom:.4rem;transform:translate(-50%) scale(.82);transform-origin:bottom center}.dock-label{font-size:.6rem}}:root[data-theme=dark]{--bg: #0c0c0c;--bg-card: #141414;--bg-card-hover: #1d1d1d;--text: #f0ede8;--text-muted: #8a8278;--accent: #C9A84C;--accent-2: #f0c060;--accent-subtle: rgba(201,168,76,.1);--accent-border: rgba(201,168,76,.22);--accent-border-hover: rgba(201,168,76,.6);--border: rgba(255,255,255,.07);--border-hover: rgba(255,255,255,.14);--dock-bg: rgba(18,18,18,.78);--tag-bg: rgba(201,168,76,.08);--tag-text: #C9A84C;--tag-border: rgba(201,168,76,.22);--stripe: rgba(255,255,255,.04);--stripe-2: rgba(255,255,255,.015)}:root[data-theme=light]{--bg: #FAF5E4;--bg-card: #F2E9CC;--bg-card-hover: #EADDB5;--text: #1a1409;--text-muted: #7a6840;--accent: #9A7020;--accent-2: #B58530;--accent-subtle: rgba(154,112,32,.1);--accent-border: rgba(154,112,32,.25);--accent-border-hover: rgba(154,112,32,.6);--border: rgba(0,0,0,.09);--border-hover: rgba(0,0,0,.18);--dock-bg: rgba(250,245,228,.84);--tag-bg: rgba(154,112,32,.1);--tag-text: #7A5818;--tag-border: rgba(154,112,32,.22);--stripe: rgba(0,0,0,.05);--stripe-2: rgba(0,0,0,.02)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{background:var(--bg);color:var(--text);font-family:Jost,system-ui,sans-serif;font-weight:400;line-height:1.6;transition:background .45s ease,color .45s ease;overflow-x:hidden}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--bg)}section{padding:7rem 8% 5rem;position:relative}.section-heading{margin-bottom:2.4rem}.section-heading.center{text-align:center;max-width:720px;margin-left:auto;margin-right:auto}.section-label{display:inline-block;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent-border);padding:.32rem .85rem;border-radius:100px;margin-bottom:1rem;font-family:Jost,sans-serif}.section-title{font-family:Cormorant Garamond,serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:500;line-height:1.1;letter-spacing:-.01em;margin-bottom:.6rem}.section-sub{color:var(--text-muted);font-size:1rem;max-width:540px;line-height:1.7}.section-heading.center .section-sub{margin-left:auto;margin-right:auto}.pill{display:inline-flex;align-items:center;font-size:.72rem;letter-spacing:.02em;background:var(--tag-bg);color:var(--tag-text);border:1px solid var(--tag-border);padding:.28rem .7rem;border-radius:100px;font-weight:400;white-space:nowrap}.hero{min-height:100vh;display:grid;grid-template-columns:1.2fr .8fr;align-items:center;gap:5%;padding-top:4rem;overflow:visible}.hero-left{min-width:0;overflow:visible}.hero-label{font-size:.72rem;letter-spacing:.22em;color:var(--text-muted);text-transform:uppercase;margin-bottom:2.2rem;font-weight:400}.hero-heading{font-family:Cormorant Garamond,serif;font-weight:500;line-height:1.3;padding-bottom:.2em;margin-bottom:2.4rem;letter-spacing:-.015em;overflow:visible}.hero-greet{display:block;font-size:clamp(2.6rem,5.4vw,4.8rem);color:var(--text);font-style:italic;font-weight:400;line-height:1.15;overflow:visible}.hero-name{display:block;font-size:clamp(3.4rem,7.2vw,6.4rem);margin-top:.2rem;margin-bottom:0;font-weight:600;line-height:1.18;overflow:visible;white-space:nowrap}.hero-name .animated-gradient-text{display:inline-block;line-height:inherit;margin:0;padding:0;overflow:visible;white-space:nowrap}.hero-interests{list-style:none;display:flex;flex-direction:column;gap:.35rem}.hero-interests li{font-size:1.05rem;color:var(--text-muted);font-weight:300;letter-spacing:.02em;position:relative;padding-left:1.5rem}.hero-interests li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:14px;height:1px;background:var(--accent);opacity:.6}.hero-right{display:flex;flex-direction:column;align-items:center;gap:1rem}.hero-photo-frame{width:min(340px,100%);position:relative;border-radius:20px;border:1.5px solid var(--accent-border);overflow:hidden;box-shadow:0 0 0 1px var(--accent-subtle),0 20px 60px #00000080,0 0 60px #c9a84c14;transition:border-color .3s,box-shadow .3s}.hero-photo-frame:hover{border-color:var(--accent-border-hover);box-shadow:0 0 0 1px var(--accent-border),0 20px 60px #00000080,0 0 80px #c9a84c2e}.hero-pixel{width:100%}.hero-photo-fill{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;border:none;background:var(--bg-card)}.hero-photo-fill--alt{background:#1a1408}.hero-hint{font-size:.7rem;letter-spacing:.22em;color:var(--text-muted);text-transform:uppercase;font-weight:400}.img-placeholder{position:relative;width:100%;background:var(--bg-card);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.img-placeholder__stripes{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-linear-gradient(135deg,var(--stripe) 0,var(--stripe) 12px,var(--stripe-2) 12px,var(--stripe-2) 24px)}.img-placeholder__label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.74rem;letter-spacing:.08em;color:var(--text-muted);text-transform:lowercase;padding:0 1rem;text-align:center}.bento-section{padding-bottom:6rem}.bento-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;grid-template-areas:"about  about  time" "skills now    bad";gap:1rem;position:relative;-webkit-user-select:none;user-select:none}.bento-time{min-height:100%}.magic-bento-card{position:relative;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:1.7rem 1.8rem;overflow:hidden;isolation:isolate;transition:background .25s,border-color .25s;--glow-color-rgb: 201, 168, 76;--glow-x: 50%;--glow-y: 50%;--glow-intensity: 0;--glow-radius: 200px}.magic-bento-card:hover{background:var(--bg-card-hover)}.magic-bento-card.with-glow:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;padding:1.5px;border-radius:inherit;background:radial-gradient(var(--glow-radius) circle at var(--glow-x) var(--glow-y),rgba(var(--glow-color-rgb),calc(var(--glow-intensity) * .95)) 0%,rgba(var(--glow-color-rgb),calc(var(--glow-intensity) * .45)) 30%,transparent 60%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:2}.bento-label{font-size:.66rem;letter-spacing:.22em;color:var(--accent);text-transform:uppercase;font-weight:500;margin-bottom:1rem}.bento-about{grid-area:about;min-height:280px;display:flex;flex-direction:column}.bento-bio p{font-size:.95rem;line-height:1.85;margin-bottom:1rem;color:var(--text);max-width:46ch}.bento-bio p:last-of-type{margin-bottom:0}.bio-link{color:var(--accent);border-bottom:1px solid var(--accent-border);transition:border-color .2s}.bio-link:hover{border-color:var(--accent)}.bento-bio strong{font-weight:600;color:var(--text)}.bento-dog{position:absolute;right:-30px;bottom:-30px;width:180px;height:180px;pointer-events:none;animation:float 3s ease-in-out infinite;opacity:.85}.dog-placeholder{position:relative;width:100%;height:100%;border-radius:24px;background:var(--bg-card-hover);border:1px solid var(--accent-border);overflow:hidden}.dog-placeholder .img-placeholder__stripes{opacity:.6}.dog-placeholder .img-placeholder__label{font-size:.62rem;color:var(--accent)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.bento-time{grid-area:time;display:flex}.time-widget{display:flex;flex-direction:column;gap:.6rem;width:100%}.time-block{display:flex;flex-direction:column;gap:.45rem}.time-label{display:flex;align-items:center;gap:.55rem;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-muted);font-weight:500}.time-label .time-mode{margin-left:auto;font-size:.58rem;border:1px solid var(--border);padding:.15rem .5rem;border-radius:6px;color:var(--text-muted)}.live-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 #4ade80b3;animation:pulse-dot 1.6s ease-out infinite}@keyframes pulse-dot{0%{box-shadow:0 0 #4ade808c}70%{box-shadow:0 0 0 8px #4ade8000}to{box-shadow:0 0 #4ade8000}}.time-value{font-family:Jost,sans-serif;font-size:clamp(2.2rem,3.2vw,3rem);font-weight:500;letter-spacing:-.01em;line-height:1;font-variant-numeric:tabular-nums}.time-tz{font-size:.78rem;color:var(--text-muted);letter-spacing:.04em}.time-divider{height:1px;background:var(--border);margin:.4rem 0}.time-diff{display:flex;align-items:center;gap:.6rem;margin:.25rem 0}.time-diff-line{flex:1;height:1px;background:var(--border)}.time-diff-label{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;font-weight:400}.bento-skills{grid-area:skills;display:flex;flex-direction:column;min-height:0;height:100%;padding-right:0;padding-left:0}.bento-skills .bento-label{padding-left:1.8rem}.skills-marquee{flex:1;display:flex;flex-direction:column;justify-content:center;gap:.5rem;overflow:hidden;mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%)}.scroll-velocity{display:flex;flex-direction:column;gap:.4rem}.sv-row{overflow:hidden;white-space:nowrap}.sv-scroller{display:inline-flex;white-space:nowrap;will-change:transform}.sv-copy{display:inline-block;font-family:Cormorant Garamond,serif;font-style:italic;font-size:clamp(1.1rem,1.6vw,1.5rem);color:var(--accent);font-weight:500;padding-right:1rem;letter-spacing:.005em}.bento-now{grid-area:now}.now-title{font-family:Cormorant Garamond,serif;font-size:1.7rem;font-weight:600;color:var(--accent);margin-bottom:.35rem;letter-spacing:-.005em}.now-desc{font-size:.88rem;color:var(--text-muted);line-height:1.65;max-width:38ch}.bento-divider{height:1px;background:var(--border);margin:1.4rem 0 1rem}.bento-bad{grid-area:bad;display:flex;flex-direction:column}.bad-desc{font-size:.88rem;color:var(--text-muted);line-height:1.65;margin-bottom:1rem;max-width:38ch}.bad-thumb{margin-top:auto;border-radius:10px;overflow:hidden;border:1px solid var(--accent-border);box-shadow:0 0 0 1px var(--accent-subtle)}.bad-thumb--ratio{position:relative;width:100%;padding-top:62%}.bad-thumb__img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}.border-glow-card{--edge-proximity: 0;--cursor-angle: 45deg;--edge-sensitivity: 30;--color-sensitivity: 50;--border-radius: 16px;--glow-padding: 35px;--cone-spread: 25;position:relative;border-radius:var(--border-radius);isolation:isolate;transform:translateZ(.01px);display:grid;border:1px solid var(--border);background:var(--card-bg, var(--bg-card));overflow:visible}.border-glow-card:before,.border-glow-card:after,.border-glow-card>.edge-light{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;transition:opacity .25s ease-out;z-index:-1}.border-glow-card:not(:hover):before,.border-glow-card:not(:hover):after,.border-glow-card:not(:hover)>.edge-light{opacity:0;transition:opacity .6s ease-in-out}.border-glow-card:before{border:1px solid transparent;background:linear-gradient(var(--card-bg, var(--bg-card)) 0 100%) padding-box,radial-gradient(at 80% 55%,var(--c1) 0px,transparent 50%) border-box,radial-gradient(at 8% 6%,var(--c3) 0px,transparent 50%) border-box,radial-gradient(at 41% 38%,var(--c2) 0px,transparent 50%) border-box,radial-gradient(at 86% 85%,var(--c2) 0px,transparent 50%) border-box,radial-gradient(at 51% 4%,var(--c1) 0px,transparent 50%) border-box,linear-gradient(var(--c1) 0 100%) border-box;opacity:calc((var(--edge-proximity) - var(--color-sensitivity)) / (100 - var(--color-sensitivity)));-webkit-mask-image:conic-gradient(from var(--cursor-angle) at center,black calc(var(--cone-spread) * 1%),transparent calc((var(--cone-spread) + 15) * 1%),transparent calc((100 - var(--cone-spread) - 15) * 1%),black calc((100 - var(--cone-spread)) * 1%));mask-image:conic-gradient(from var(--cursor-angle) at center,black calc(var(--cone-spread) * 1%),transparent calc((var(--cone-spread) + 15) * 1%),transparent calc((100 - var(--cone-spread) - 15) * 1%),black calc((100 - var(--cone-spread)) * 1%))}.border-glow-card>.edge-light{inset:calc(var(--glow-padding) * -1);pointer-events:none;z-index:0;-webkit-mask-image:conic-gradient(from var(--cursor-angle) at center,black 2.5%,transparent 10%,transparent 90%,black 97.5%);mask-image:conic-gradient(from var(--cursor-angle) at center,black 2.5%,transparent 10%,transparent 90%,black 97.5%);opacity:calc((var(--edge-proximity) - var(--edge-sensitivity)) / (100 - var(--edge-sensitivity)));mix-blend-mode:plus-lighter}.border-glow-card>.edge-light:before{content:"";position:absolute;inset:var(--glow-padding);border-radius:inherit;box-shadow:inset 0 0 0 1px var(--glow-color),inset 0 0 6px 0 var(--glow-40),inset 0 0 18px 0 var(--glow-20),0 0 3px 0 var(--glow-60),0 0 12px 0 var(--glow-40),0 0 30px 2px var(--glow-20),0 0 50px 2px var(--glow-10)}.border-glow-inner{display:flex;flex-direction:column;position:relative;z-index:1;padding:1.5rem 1.7rem}.resume-section{padding-top:5rem}.resume-section+.resume-section{padding-top:1rem}.resume-grid{display:grid;grid-template-columns:220px 1fr;gap:4rem}.resume-side{position:sticky;top:6rem;align-self:start}.resume-side-label{font-family:Cormorant Garamond,serif;font-size:1.6rem;font-weight:500;color:var(--text-muted);letter-spacing:.01em;display:inline-block}.resume-entries{display:flex;flex-direction:column;gap:1.2rem;margin-top:1.8rem}.resume-entry{background:var(--bg-card)}.resume-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.resume-title{font-family:Jost,sans-serif;font-size:1.05rem;font-weight:500;color:var(--text);letter-spacing:0;line-height:1.35}.resume-date{flex-shrink:0;font-size:.72rem;letter-spacing:.04em;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--accent-border);padding:.28rem .7rem;border-radius:100px;white-space:nowrap;margin-top:.15rem}.resume-company{font-size:.92rem;color:var(--text-muted);margin-top:.35rem;letter-spacing:.005em}.resume-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:1rem}.resume-bullets{list-style:none;margin-top:1.1rem;padding-left:.2rem;display:flex;flex-direction:column;gap:.7rem}.resume-bullets li{position:relative;padding-left:1.3rem;font-size:.92rem;color:var(--text);line-height:1.7}.resume-bullets li:before{content:"–";position:absolute;left:0;color:var(--accent);font-weight:400}.course-btn{margin-top:1.1rem;background:transparent;border:none;color:var(--accent);font-family:Jost,sans-serif;font-size:.83rem;letter-spacing:.04em;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 0;transition:color .2s}.course-btn:hover{color:var(--accent-2)}.course-chev{transition:transform .3s ease;display:inline-block}.course-chev.open{transform:rotate(180deg)}.course-panel{overflow:hidden;transition:max-height .45s ease}.course-grid{padding:.4rem 0 .2rem;display:grid;grid-template-columns:1fr 1fr;gap:.4rem 1rem}.course-item{font-size:.86rem;color:var(--text-muted);line-height:1.8}.course-bullet{color:var(--accent);margin-right:.3rem}.electric-border{position:relative;isolation:isolate;--eb-color: #C9A84C;width:min(340px,100%)}.electric-border .eb-canvas-wrap{position:absolute;top:-60px;right:-60px;bottom:-60px;left:-60px;pointer-events:none;z-index:1}.electric-border .eb-canvas-wrap canvas{width:100%;height:100%;display:block}.electric-border .eb-bg-glow{position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:inherit;background:radial-gradient(circle at 50% 50%,color-mix(in oklab,var(--eb-color),transparent 75%),transparent 70%);filter:blur(20px);z-index:0;pointer-events:none}.electric-border .eb-glow{display:none}.electric-border .eb-content{position:relative;z-index:2;border:1px solid var(--accent-border);background:var(--bg-card);overflow:hidden;transition:border-color .3s,box-shadow .3s}.electric-border:hover .eb-content{border-color:var(--accent-border-hover);box-shadow:inset 0 0 0 1px var(--accent-border-hover),0 0 40px #c9a84c40,0 0 80px #c9a84c2e}.about-pager{display:flex;flex-direction:column;gap:1rem;flex:1}.about-pager-head{display:flex;align-items:center;justify-content:space-between;gap:1rem}.about-pager-page{font-size:.66rem;letter-spacing:.22em;color:var(--text-muted);font-weight:500}.about-pager-stage{position:relative;min-height:6.5rem;flex:1}.about-pager-slide{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transform:translateY(8px);transition:opacity .5s ease,transform .5s ease;pointer-events:none}.about-pager-slide.is-active{opacity:1;transform:translateY(0);pointer-events:auto}.about-pager-slide .bento-bio p{font-size:.98rem;line-height:1.8;margin-bottom:.85rem;max-width:80ch}.about-pager-controls{display:flex;align-items:center;justify-content:center;gap:1.25rem;padding-top:.25rem}.about-arrow{background:transparent;border:1px solid var(--accent-border);color:var(--accent);width:32px;height:32px;border-radius:50%;font-size:1.1rem;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s}.about-arrow:hover{border-color:var(--accent);background:#c9a84c14}.about-dots{display:flex;gap:.5rem;align-items:center}.about-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--accent-border);cursor:pointer;padding:0;transition:background .25s,transform .25s,width .3s}.about-dot.is-active{background:var(--accent);width:22px;border-radius:4px}.skills-panel{display:flex;flex-direction:column;flex:1;min-height:0;width:100%;height:100%;gap:.75rem;position:relative;outline:none}.skills-panel-body{position:relative;flex:1;min-height:clamp(260px,32vw,340px);width:100%;overflow:hidden}.skills-head{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:0 1.8rem;gap:.35rem;flex-shrink:0}.skills-head .bento-label{margin-bottom:0}.skills-marquee-css{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-start;gap:0;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);transition:opacity .3s ease,transform .3s ease}.skills-marquee-rows{flex:1;min-height:0;display:flex;flex-direction:column;justify-content:space-between;gap:.28rem;padding-bottom:2.75rem;box-sizing:border-box}.skills-marquee-row{flex:1 1 0;min-height:0;overflow:hidden;display:flex;align-items:center}.skills-marquee-css.skills-hidden{opacity:0;transform:scale(.96);pointer-events:none}.skills-track{display:flex;gap:.6rem;width:max-content;white-space:nowrap}.skills-track-l{animation-name:skills-scroll-l;animation-timing-function:linear;animation-iteration-count:infinite}.skills-track-r{animation-name:skills-scroll-r;animation-timing-function:linear;animation-iteration-count:infinite}.skills-marquee-row:nth-child(1) .skills-track{animation-duration:24s}.skills-marquee-row:nth-child(2) .skills-track{animation-duration:30s}.skills-marquee-row:nth-child(3) .skills-track{animation-duration:27s}.skills-marquee-row:nth-child(4) .skills-track{animation-duration:33s}.skills-marquee-row:nth-child(5) .skills-track{animation-duration:26s}.skills-panel:hover .skills-marquee-css:not(.skills-hidden) .skills-track{animation-play-state:paused}.skills-marquee-row .skill-chip{font-size:.74rem;padding:.32rem .72rem}@keyframes skills-scroll-l{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes skills-scroll-r{0%{transform:translate(-50%)}to{transform:translate(0)}}.skill-chip{display:inline-flex;align-items:center;padding:.4rem .85rem;border-radius:999px;border:1px solid var(--accent-border);background:#c9a84c0a;color:var(--text);font-size:.82rem;letter-spacing:.02em}.skills-tap-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);z-index:6;font-size:.6rem;letter-spacing:.3em;color:var(--text-muted);opacity:.55;pointer-events:none}.skills-panel.is-revealed .skills-tap-hint{visibility:hidden}.skills-pills{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;overflow:hidden;padding:0;opacity:0;transform:scale(.96);transition:opacity .3s ease,transform .3s ease;pointer-events:none}.skills-pills.skills-visible{opacity:1;transform:scale(1);pointer-events:auto;overflow:hidden}.skills-pills-scroll{flex:1 1 auto;min-height:0;height:100%;overflow-y:auto;overflow-x:hidden;padding:.35rem .6rem .5rem 1.8rem;margin-right:.2rem;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.skills-scroll-hint{align-self:stretch;width:100%;font-size:11px;text-transform:uppercase;letter-spacing:.12em;text-align:center;color:var(--text-muted);opacity:.65;line-height:1.35;margin-bottom:.75rem;pointer-events:none}.skills-pills-scroll::-webkit-scrollbar{width:5px}.skills-pills-scroll::-webkit-scrollbar-track{background:transparent}.skills-pills-scroll::-webkit-scrollbar-thumb{background:var(--accent);border-radius:100px}.skills-cat-block{margin-bottom:.65rem}.skills-cat-block:last-child{margin-bottom:.25rem}.skills-cat-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.4rem}.skills-cat-pills{display:flex;flex-wrap:wrap;gap:.45rem}.skill-pill{animation:skill-pill-in .5s ease both}@keyframes skill-pill-in{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.projects-section{padding-top:5rem;padding-bottom:8rem}.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;max-width:1100px;margin:2.5rem auto 0}.project-card{display:flex;flex-direction:column;transition:transform .2s ease}.project-card:hover{transform:translateY(-3px)}.project-card .border-glow-inner{gap:.6rem;flex:1}.project-card:last-child:nth-child(odd){grid-column:1 / -1;max-width:560px;margin:0 auto;width:100%}.psc-date{font-size:.72rem;letter-spacing:.04em;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--accent-border);padding:.28rem .7rem;border-radius:100px;white-space:nowrap;align-self:flex-start}.psc-title{font-family:Cormorant Garamond,serif;font-size:1.35rem;font-weight:600;letter-spacing:-.005em;line-height:1.2;color:var(--text)}.psc-desc{font-size:.88rem;line-height:1.75;color:var(--text-muted);margin:0;flex:1}.psc-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:auto}.connect-section{padding-bottom:8rem}.connect-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-top:2rem;max-width:900px;margin-left:auto;margin-right:auto;width:100%}.connect-cards>.connect-link{width:100%;min-width:0}.connect-link{display:block}button.connect-link{width:100%;font:inherit;color:inherit;background:none;border:none;padding:0;margin:0;cursor:pointer;text-align:inherit}button.connect-link:disabled{cursor:wait;opacity:.85}.connect-card{display:flex;flex-direction:row!important;align-items:center;gap:.9rem;min-height:100%;min-width:0}.connect-card .border-glow-inner{flex-direction:row;align-items:center;gap:.9rem;padding:1rem 1.4rem}.connect-icon{width:42px;height:42px;border-radius:10px;background:var(--accent-subtle);border:1px solid var(--accent-border);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.connect-name{font-size:.95rem;font-weight:500;color:var(--text)}.connect-sub{font-size:.78rem;color:var(--text-muted);margin-top:.1rem}footer{text-align:center;padding:2.5rem 8% 6.5rem;border-top:1px solid var(--border);font-size:.8rem;color:var(--text-muted);letter-spacing:.04em}.scroll-reveal{display:inline-block}.scroll-reveal.section-title,.scroll-reveal.section-sub{display:block}@media(max-width:768px){.connect-cards{grid-template-columns:1fr;justify-items:stretch;max-width:min(360px,100%)}}@media(max-width:900px){section{padding:5rem 6% 3.5rem}.hero{grid-template-columns:1fr;gap:2.5rem;padding-top:6rem}.hero-name{font-size:clamp(1.85rem,6.2vw,3.5rem)}.hero-right{order:-1;align-items:flex-start}.hero-photo-frame{width:min(280px,80%)}.bento-grid{grid-template-columns:1fr 1fr;grid-template-areas:"about  about" "time   skills" "now    bad"}.bento-about{min-height:auto}.resume-grid{grid-template-columns:1fr;gap:1.5rem}.resume-side{position:static}.resume-row{flex-direction:column}.resume-date{margin-top:.5rem}.projects-grid{grid-template-columns:1fr}.project-card:last-child:nth-child(odd){max-width:100%}.course-grid{grid-template-columns:1fr}}@media(max-width:768px){section{padding:4rem 5% 3rem}.section-title{font-size:clamp(1.6rem,5vw,2.4rem)}.section-sub{font-size:.9rem}.section-label{font-size:.62rem;padding:.25rem .7rem}.hero{min-height:auto;gap:2rem;padding-top:5rem;padding-bottom:2rem}.hero-photo-frame{width:min(220px,65%)}.hero-heading{line-height:1.08;margin-bottom:1.6rem}.hero-greet{font-size:clamp(1.8rem,6vw,2.6rem)}.hero-name{font-size:clamp(2.2rem,8vw,3.4rem)}.hero-label{font-size:.65rem;margin-bottom:1.4rem}.hero-interests li{font-size:.92rem}.bento-grid{grid-template-columns:1fr;grid-template-areas:"about" "time" "skills" "now" "bad"}.bento-about{position:relative;min-height:340px}.about-pager{position:relative;padding-bottom:3.5rem}.about-pager-stage{min-height:10rem}.about-pager-controls{position:absolute;bottom:1rem;left:0;right:0}.bento-section{padding-bottom:4rem}.bento-dog{width:120px;height:120px;right:-16px;bottom:-16px}.about-pager-slide .bento-bio p{font-size:.88rem}.time-value{font-size:clamp(1.8rem,6vw,2.4rem)}.resume-grid{gap:1rem}.resume-side-label{font-size:1.3rem}.resume-title{font-size:.95rem}.resume-company,.resume-bullets li{font-size:.84rem}.resume-entries{gap:1rem;margin-top:1.2rem}.border-glow-inner{padding:1.2rem 1.3rem}.projects-section{padding-bottom:5rem}.psc-title{font-size:1.15rem}.psc-desc{font-size:.82rem}.connect-cards{flex-direction:column;align-items:center}.connect-card{min-width:0;width:100%;max-width:320px}footer{padding-bottom:5.5rem;font-size:.75rem}.skills-marquee-row:nth-child(n+4){display:none}.skills-marquee-rows{gap:.4rem}.skills-marquee-row .skill-chip{font-size:.68rem;padding:.25rem .6rem}.skills-pills{padding:.5rem 1rem}.skill-chip{font-size:.75rem;padding:.3rem .7rem}}
