@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/e1aab0933260df4d-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/b7387a63dd068245-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:Space Grotesk;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/36966cca54120369-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:Space Grotesk Fallback;src:local("Arial");ascent-override:89.71%;descent-override:26.62%;line-gap-override:0.00%;size-adjust:109.69%}.__className_c22fe1{font-family:Space Grotesk,Space Grotesk Fallback;font-style:normal}.__variable_c22fe1{--font-main:"Space Grotesk","Space Grotesk Fallback"}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:var(--font-main),Space Grotesk,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.block{display:block}.flex{display:flex}.table{display:table}.shrink{flex-shrink:1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.lowercase{text-transform:lowercase}:root{--bg:oklch(0.985 0.002 90);--bg2:oklch(0.965 0.004 90);--fg:oklch(0.205 0.02 60);--fg-muted:oklch(0.45 0.015 60);--fg-faint:oklch(0.62 0.01 60);--accent:oklch(0.55 0.18 264);--accent2:oklch(0.65 0.22 300);--border:oklch(0.88 0.005 90);--border2:oklch(0.82 0.008 90)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-main),"Space Grotesk",sans-serif;background:var(--bg);color:var(--fg);text-transform:lowercase;line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,var(--fg-faint) 1px,transparent 1px);background-size:28px 28px;opacity:.18}body>*{position:relative;z-index:1}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;border:none;background:none;color:inherit}button,input,textarea{font-family:inherit;text-transform:lowercase}.scroll-progress{height:3px;z-index:9999;background:oklch(.75 .08 264);transition:width .1s linear}.navbar,.scroll-progress{position:fixed;top:0;left:0}.navbar{right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:56px;background:oklch(.985 .002 90/.8);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color .3s;border-bottom:1px solid var(--border)}.nav-logo{font-size:1.15rem;font-weight:700;letter-spacing:-.5px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.nav-links{display:flex;gap:1.75rem;align-items:center}.nav-link{position:relative;font-size:.85rem;font-weight:400;color:var(--fg-muted);transition:color .2s;padding:4px 0}.nav-link.active,.nav-link:hover{color:var(--fg)}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--accent);transition:width .25s ease}.nav-link.active:after,.nav-link:hover:after{width:100%}.main-content{max-width:900px;margin:0 auto;padding:100px 2rem 4rem}.hero-eyebrow{font-size:.8rem;color:var(--fg-muted);letter-spacing:.5px;margin-bottom:1rem}.hero-headline{font-size:clamp(2.625rem,5vw + 1rem,4.75rem);font-weight:700;line-height:1.1;letter-spacing:-1.5px;margin-bottom:1.25rem}.hero-sub{font-size:.95rem;color:var(--fg-muted);max-width:560px;line-height:1.7;margin-bottom:1.5rem}.adobe-hover{transition:color .2s}.adobe-hover:hover{color:oklch(.55 .22 25)}.hero-badges{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:3rem}.badge{font-size:.78rem;padding:.4rem 1rem;border:1.5px solid var(--border2);border-radius:999px;color:var(--fg-muted);background:var(--bg);transition:border-color .2s,color .2s,box-shadow .2s;cursor:default}.badge.badge-active,.badge:hover{border-color:oklch(.75 .12 264);color:oklch(.45 .14 264);box-shadow:0 0 0 2px oklch(.75 .12 264/.15)}.terminal{background:oklch(.17 .01 260);border-radius:10px;overflow:hidden;margin-bottom:3.5rem;box-shadow:0 4px 24px oklch(0 0 0/.12)}.terminal-header{display:flex;align-items:center;gap:6px;padding:12px 16px;background:oklch(.22 .01 260)}.terminal-dot{width:12px;height:12px;border-radius:50%}.terminal-dot.red{background:#ff5f57}.terminal-dot.yellow{background:#febc2e}.terminal-dot.green{background:#28c840}.terminal-body{padding:1.25rem 1.5rem;font-size:.85rem;line-height:1.8;color:oklch(.8 .01 90);min-height:180px}.terminal-line{opacity:0;white-space:pre-wrap;word-break:break-word}.terminal-line.visible{opacity:1;animation:fadeUp .3s ease forwards}.terminal-line .cmd{color:oklch(.72 .18 160)}.terminal-line .str{color:oklch(.75 .15 85)}.terminal-line .key{color:oklch(.7 .17 264)}.terminal-line .val{color:oklch(.78 .12 60)}.terminal-cursor{display:inline-block;width:8px;height:1.1em;background:oklch(.72 .18 160);animation:blink 1s step-end infinite;vertical-align:text-bottom;margin-left:2px}.section-label{font-size:.8rem;color:var(--fg-faint);margin-bottom:1rem}.tech-pills{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:3.5rem}.tech-pill{font-size:.8rem;padding:.4rem 1rem;border:1px solid var(--border2);border-radius:6px;color:var(--fg-muted);background:var(--bg);transition:transform .2s,box-shadow .2s,border-color .2s}.tech-pill:hover{transform:translateY(-2px);box-shadow:0 4px 12px oklch(0 0 0/.06);border-color:var(--accent);color:var(--fg)}.projects-header{margin-bottom:2rem}.projects-header h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-1px;margin-bottom:.5rem}.projects-header p{color:var(--fg-muted);font-size:.9rem}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:3rem}.project-card{position:relative;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--bg);transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-4px) perspective(800px) rotateX(1deg);box-shadow:0 12px 32px oklch(0 0 0/.08)}.project-card:before{content:"";position:absolute;inset:0;border-radius:12px;opacity:0;transition:opacity .3s;background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),oklch(.55 .18 264/.06),transparent 60%);pointer-events:none;z-index:1}.project-card:hover:before{opacity:1}.project-image-wrapper{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--bg2)}.project-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.project-number{position:absolute;top:12px;left:12px;font-size:.7rem;font-weight:600;color:var(--fg-faint);background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:2px 10px;z-index:2}.project-content{padding:1.25rem}.project-title{font-size:1.05rem;font-weight:600;margin-bottom:.5rem}.project-description{font-size:.8rem;color:var(--fg-muted);line-height:1.6;margin-bottom:.75rem}.project-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.75rem}.project-tag{font-size:.7rem;padding:.2rem .5rem;border:1px solid var(--border);border-radius:4px;color:var(--fg-faint)}.project-footer{display:flex;align-items:center;justify-content:space-between}.project-link-btn{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;color:var(--accent);transition:gap .2s}.project-link-btn:hover{gap:10px}.project-date-text{font-size:.72rem;color:var(--fg-faint)}.see-all-link{display:inline-block;font-size:.85rem;color:var(--accent);margin-top:.5rem;transition:letter-spacing .2s}.see-all-link:hover{letter-spacing:.5px}.chat-page{display:flex;flex-direction:column;height:calc(100vh - 56px);max-width:720px;margin:0 auto;padding:80px 2rem 1.5rem}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-bottom:1rem}.chat-welcome{text-align:center;padding:3rem 1rem;color:var(--fg-muted)}.chat-welcome h2{font-size:1.25rem;font-weight:600;color:var(--fg);margin-bottom:.5rem}.chat-welcome p{font-size:.85rem;margin-bottom:1.5rem}.chat-suggestions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.chat-suggestion{font-size:.78rem;padding:.4rem .85rem;border:1px solid var(--border2);border-radius:999px;color:var(--fg-muted);transition:border-color .2s,color .2s}.chat-suggestion:hover{border-color:var(--accent);color:var(--fg)}.chat-bubble{max-width:75%;padding:.75rem 1rem;border-radius:12px;font-size:.85rem;line-height:1.6;animation:msgIn .3s ease forwards}.chat-bubble.user{align-self:flex-end;background:oklch(.94 .04 264);color:var(--fg);border-bottom-right-radius:4px}.chat-bubble.assistant{align-self:flex-start;background:var(--bg2);border:1px solid var(--border);border-bottom-left-radius:4px}.chat-avatar{font-size:.65rem;font-weight:600;color:var(--fg-faint);margin-bottom:4px}.chat-bubble.user .chat-avatar{text-align:right;color:var(--fg-faint)}.chat-typing{display:flex;gap:4px;padding:.75rem 1rem;align-self:flex-start}.chat-typing span{width:6px;height:6px;border-radius:50%;background:var(--fg-faint);animation:typingDot 1.4s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}.chat-input-row{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid var(--border)}.chat-input{flex:1;padding:.65rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--fg);font-size:.85rem;outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--accent)}.chat-send-btn{padding:.65rem 1.25rem;background:var(--fg);color:var(--bg);border-radius:8px;font-size:.8rem;font-weight:500;transition:opacity .2s}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-social-links{display:inline}.chat-social-link{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.visitors-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.visitors-header-text h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;letter-spacing:-1px}.visitors-header-text p{color:var(--fg-muted);font-size:.85rem;margin-top:.35rem}.visitors-actions{display:flex;align-items:center;gap:1rem}.note-count{font-size:.78rem;color:var(--fg-faint)}.leave-note-btn{padding:.5rem 1.1rem;background:var(--accent);color:white;border-radius:8px;font-size:.8rem;font-weight:500;transition:opacity .2s}.leave-note-btn:hover{opacity:.85}.notes-board{position:relative;min-height:600px;border:2px dashed var(--border2);border-radius:12px;padding:2rem;margin-bottom:3rem;overflow:hidden}.notes-empty{inset:0;align-items:center;justify-content:center;color:var(--fg-faint);font-size:.9rem}.notes-empty,.sticky-note{position:absolute;display:flex}.sticky-note{width:220px;min-height:160px;padding:1rem;border-radius:4px;box-shadow:0 4px 16px oklch(0 0 0/.1);cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-direction:column;font-size:.78rem}.sticky-note:active{cursor:grabbing;z-index:10}.sticky-note-color-0{background:oklch(.95 .06 95)}.sticky-note-color-1{background:oklch(.93 .06 150)}.sticky-note-color-2{background:oklch(.93 .06 264)}.sticky-note-color-3{background:oklch(.95 .06 30)}.sticky-note-color-4{background:oklch(.93 .06 330)}.sticky-note-author{font-weight:600;margin-bottom:.35rem;font-size:.72rem;opacity:.7}.sticky-note-message{flex:1;line-height:1.5;margin-bottom:.5rem;word-break:break-word}.sticky-note-canvas{width:100%;height:60px;border-radius:4px;background:oklch(1 0 0/.3)}.composer-overlay{position:fixed;inset:0;z-index:200;background:oklch(0 0 0/.4);display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease}.composer-modal{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:1.75rem;width:100%;max-width:420px;animation:fadeUp .3s ease}.composer-modal h3{font-size:1rem;font-weight:600;margin-bottom:1.25rem}.composer-field{margin-bottom:1rem}.composer-field label{display:block;font-size:.75rem;color:var(--fg-muted);margin-bottom:.35rem}.composer-field input,.composer-field textarea{width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--fg);font-size:.82rem;outline:none;transition:border-color .2s}.composer-field input:focus,.composer-field textarea:focus{border-color:var(--accent)}.composer-field textarea{resize:vertical;min-height:80px}.composer-colors{display:flex;gap:.5rem;margin-bottom:1rem}.composer-color-dot{width:24px;height:24px;border-radius:50%;border:2px solid transparent;transition:border-color .2s,transform .2s}.composer-color-dot:hover{transform:scale(1.15)}.composer-color-dot.selected{border-color:var(--fg)}.composer-color-dot.c0{background:oklch(.95 .06 95)}.composer-color-dot.c1{background:oklch(.93 .06 150)}.composer-color-dot.c2{background:oklch(.93 .06 264)}.composer-color-dot.c3{background:oklch(.95 .06 30)}.composer-color-dot.c4{background:oklch(.93 .06 330)}.composer-canvas-wrapper{margin-bottom:1rem}.composer-canvas-wrapper label{display:block;font-size:.75rem;color:var(--fg-muted);margin-bottom:.35rem}.composer-canvas{width:100%;height:100px;border:1px solid var(--border);border-radius:6px;cursor:crosshair;touch-action:none;transition:height .2s ease}.composer-canvas-expanded{height:360px}.canvas-expand-btn{background:none;border:1px solid var(--border);border-radius:4px;color:var(--fg-muted);font-size:.7rem;font-family:var(--font-main);padding:.15rem .5rem;cursor:pointer;transition:color .15s,border-color .15s}.canvas-expand-btn:hover:not(:disabled){color:var(--fg);border-color:var(--fg-muted)}.canvas-expand-btn:disabled{opacity:.35;cursor:default}.composer-actions{display:flex;gap:.5rem;justify-content:flex-end}.composer-cancel{padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.8rem;color:var(--fg-muted);transition:border-color .2s}.composer-cancel:hover{border-color:var(--fg-muted)}.composer-post{padding:.5rem 1rem;background:var(--accent);color:white;border-radius:8px;font-size:.8rem;font-weight:500;transition:opacity .2s}.composer-post:hover{opacity:.85}.footer{max-width:900px;margin:0 auto;padding:2rem;border-top:1px solid var(--border)}.spotify-widget{display:flex;align-items:center;gap:.75rem;padding:.85rem 1rem;border:1px solid var(--border);border-radius:10px;margin-bottom:1.5rem;text-decoration:none;transition:border-color .2s}.spotify-widget:hover{border-color:var(--border2)}.spotify-album-art{width:44px;height:44px;border-radius:6px;overflow:hidden;flex-shrink:0}.spotify-album-art img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.spotify-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.spotify-label{font-size:.65rem;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.5px}.spotify-track-name{font-size:.82rem;font-weight:500}.spotify-artist,.spotify-track-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.spotify-artist{font-size:.72rem;color:var(--fg-muted)}.spotify-progress-bar{width:100%;height:3px;background:var(--border);border-radius:2px;margin-top:4px;overflow:hidden}.spotify-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width 1s linear}.spotify-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.spotify-equalizer{display:flex;align-items:flex-end;gap:2px;height:16px}.spotify-equalizer .bar{width:3px;background:var(--accent);border-radius:1px;animation:barBounce 1.2s ease-in-out infinite}.spotify-equalizer .bar:first-child{height:60%;animation-delay:0s}.spotify-equalizer .bar:nth-child(2){height:100%;animation-delay:.2s}.spotify-equalizer .bar:nth-child(3){height:40%;animation-delay:.4s}.spotify-icon{width:20px;height:20px;color:var(--fg-faint)}.spotify-skeleton-art{width:44px;height:44px;border-radius:6px}.spotify-skeleton-art,.spotify-skeleton-line{background:var(--border);animation:shimmer 1.5s infinite}.spotify-skeleton-line{height:10px;border-radius:4px;width:70%}.spotify-skeleton-line.short{width:40%}.spotify-skeleton-line.medium{width:55%}.footer-bottom{justify-content:space-between;flex-wrap:wrap}.footer-bottom,.social-links{display:flex;align-items:center;gap:1rem}.social-links a{color:var(--fg-faint);transition:color .2s;display:flex}.social-links a:hover{color:var(--fg)}.last-updated{font-size:.72rem;color:var(--fg-faint)}.achievement-toast{position:fixed;bottom:1.5rem;left:1.5rem;z-index:300;display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;background:var(--fg);color:var(--bg);border-radius:10px;font-size:.8rem;box-shadow:0 8px 24px oklch(0 0 0/.2);animation:fadeUp .4s ease}.achievement-icon{font-size:1.2rem}.achievement-text{display:flex;flex-direction:column}.achievement-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;opacity:.7}.achievement-desc{font-weight:500}.confetti-particle{position:fixed;width:8px;height:8px;border-radius:2px;pointer-events:none;z-index:9999;animation:confettiFall 1.5s ease-out forwards}.word-reveal-container{display:inline}.word-reveal-word{display:inline-block;opacity:0;transform:translateY(8px);transition:opacity .4s ease,transform .4s ease;margin-right:.3em}.word-reveal-word.revealed{opacity:1;transform:translateY(0)}.scroll-reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.scroll-reveal.visible{opacity:1;transform:translateY(0)}.blog-post-container{max-width:680px}.blog-post-header{margin-bottom:2rem}.blog-post-header h1{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700;letter-spacing:-.5px;margin-bottom:.5rem}.blog-post-header p{color:var(--fg-muted);font-size:.82rem}.blog-post-content{font-size:.9rem;line-height:1.8;color:var(--fg-muted)}.blog-post-content p{margin-bottom:1.25rem}.back-link{font-size:.82rem;color:var(--fg-muted);display:inline-block;margin-bottom:1.5rem;transition:color .2s}.back-link:hover{color:var(--fg)}.post-list{display:flex;flex-direction:column;gap:1.25rem}.post-item{animation:fadeUp .5s ease forwards;opacity:0}.post-item .post-title{font-size:1rem;font-weight:500;display:block;margin-bottom:.25rem;transition:color .2s}.post-item .post-title:hover{color:var(--accent)}.post-item .post-date{font-size:.75rem;color:var(--fg-faint)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes barBounce{0%,to{transform:scaleY(.4)}50%{transform:scaleY(1)}}@keyframes typingDot{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes confettiFall{0%{opacity:1;transform:translate(var(--x),var(--y)) rotate(0deg)}to{opacity:0;transform:translate(calc(var(--x) + var(--dx)),calc(var(--y) + var(--dy))) rotate(var(--rot))}}@keyframes shimmer{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}.main-content{padding:88px 1.25rem 3rem}.navbar{padding:0 1.25rem}.nav-links{gap:1.25rem}.hero-headline{letter-spacing:-1px}.chat-page{padding:72px 1rem 1rem}.chat-bubble{max-width:88%}.footer-bottom,.visitors-header{flex-direction:column;align-items:flex-start}}@media (max-width:480px){.nav-links{gap:1rem}.nav-link{font-size:.78rem}.hero-headline{font-size:2rem}.sticky-note{width:180px;min-height:130px}}