html,body,#root{height:100%;min-height:100%}body{margin:0;overflow:hidden;font-family:Cera Pro,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}@font-face{font-family:Cera Pro;src:local("Cera Pro Regular"),local("CeraPro-Regular"),url(/assets/CeraProRegular-CZkA5h4U.woff2) format("woff2");font-style:normal;font-weight:400;font-display:swap}@font-face{font-family:Cera Pro;src:local("Cera Pro Medium"),local("CeraPro-Medium"),url(/assets/CeraProMedium-FlHQqmUR.woff2) format("woff2");font-style:normal;font-weight:500;font-display:swap}@font-face{font-family:Cera Pro;src:local("Cera Pro Bold"),local("CeraPro-Bold"),url(/assets/CeraProBold-BHGwoH9Z.woff2) format("woff2");font-style:normal;font-weight:700;font-display:swap}@font-face{font-family:Cera Pro;src:local("Cera Pro Italic"),local("CeraPro-RegularItalic"),url(/assets/CeraProRegularItalic-DaAq5qC_.woff2) format("woff2");font-style:italic;font-weight:400;font-display:swap}:root{--viewport-h: 100svh;--font-sans: "Cera Pro", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--bg: #c8c8c8;--panel: #f4f4f4;--panel-border: #dddddd;--text: #141414;--text-muted: #7d7d7d;--brand-dot: #141414;--brand-dot-accent: var(--blue);--blue: #2f80ff;--blue-dark: #1162e0;--card-shadow: 0 20px 45px rgb(10 10 10 / 9%);--line-soft: rgb(255 255 255 / 65%)}@supports (height: 100dvh){:root{--viewport-h: 100dvh}}[data-theme=dark]{--bg: #1f2023;--panel: #232529;--panel-border: #363940;--text: #f4f5f7;--text-muted: #adb3bf;--brand-dot: #f4f5f7;--brand-dot-accent: var(--blue);--card-shadow: 0 20px 45px rgb(0 0 0 / 35%)}*,*:before,*:after{box-sizing:border-box}.app-shell{height:var(--viewport-h);min-height:var(--viewport-h);display:block;background:radial-gradient(circle at 45% -5%,#d7d7d7 0%,var(--bg) 52%,#bdbdbd 100%);padding:0}.hero-frame{width:100%;height:var(--viewport-h);min-height:var(--viewport-h);display:flex;flex-direction:column;border-radius:0;border:1px solid #d9d9d9;background:var(--panel);box-shadow:none;padding:.75rem}.top-nav{position:relative;flex-wrap:wrap;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.42rem 1rem .82rem}.brand{display:inline-flex;align-items:center;gap:.7rem;color:var(--text);text-decoration:none}.brand-copy{display:inline-flex;flex-direction:column;justify-content:center;line-height:1}.brand-name{font:700 .98rem/1 var(--font-sans);letter-spacing:.005em}.brand-role{margin-top:.1rem;color:var(--text-muted);font:600 .6rem/1.05 var(--font-sans);text-transform:uppercase;letter-spacing:.08em}.brand-mark{width:1.8rem;aspect-ratio:1}.brand-mark img{display:block;width:100%;height:100%;object-fit:contain}.brand-dot{display:block;width:100%;aspect-ratio:1;border-radius:999px;background:var(--brand-dot);transition:transform .18s ease}.brand-dot-accent{background:var(--brand-dot-accent)}.brand-mark:hover .brand-dot{transform:scale(1.18)}.brand-mark:hover .brand-dot:nth-child(1){transform:translate(-1px,-1px) scale(1.18)}.brand-mark:hover .brand-dot:nth-child(2){transform:translate(1px,-1px) scale(1.18)}.brand-mark:hover .brand-dot:nth-child(3){transform:translate(-1px,1px) scale(1.18)}.brand-mark:hover .brand-dot:nth-child(4){transform:translate(1px,1px) scale(1.18)}.top-nav-links{display:flex;align-items:center;gap:clamp(.9rem,3vw,2.2rem)}.top-nav-links a,.top-nav-links button{color:#424242;background:transparent;border:0;padding:0;text-decoration:none;font:500 .88rem/1.2 var(--font-sans);transition:color .16s ease;cursor:pointer}.top-nav-links a:hover,.top-nav-links button:hover{color:#1d1d1d}.top-nav-links a.is-active,.top-nav-links button.is-active{color:var(--blue)}.top-nav-actions{display:flex;align-items:center;gap:.65rem}.top-nav-actions .btn-primary{box-shadow: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}.theme-picker{position:relative}.theme-trigger{min-width:124px;border-radius:10px;border:1px solid #e1e1e1;background:#f8f8f8;color:#2f2f2f;font:600 .88rem/1 var(--font-sans);padding:.56rem .62rem .56rem .74rem;display:inline-flex;align-items:center;justify-content:space-between;gap:.45rem;text-align:left;box-shadow:none;cursor:pointer;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}.theme-trigger:hover{transform:translateY(-1px)}.theme-trigger:focus-visible{outline:2px solid rgb(47 128 255 / 24%);outline-offset:1px}.theme-trigger.is-open{border-color:#d4d4d4;box-shadow:none}.theme-trigger-value{display:inline-flex;align-items:center;gap:.35rem;white-space:nowrap}.theme-trigger-chevron{display:inline-flex;align-items:center;justify-content:center;color:#4d4d4d}.theme-panel{position:absolute;z-index:20;top:calc(100% + .5rem);left:0;width:max-content;min-width:210px;max-width:260px;border-radius:14px;border:1px solid rgb(215 219 228 / 72%);background:linear-gradient(180deg,#f8f9fcc7,#f2f4f8ad);box-shadow:0 16px 35px #00000029;backdrop-filter:blur(10px) saturate(132%);-webkit-backdrop-filter:blur(10px) saturate(132%);padding:.4rem;display:grid;gap:.28rem}.theme-option{width:100%;text-align:left;border:1px solid transparent;border-radius:10px;background:#ffffff2e;color:#2f2f2f;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;padding:.5rem .54rem;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,transform .18s ease}.theme-option:hover{background:#ffffff57;border-color:#cdd6e9c7;transform:translateY(-1px)}.theme-option-main{display:inline-flex;align-items:center;gap:.38rem;font:600 .82rem/1.1 var(--font-sans)}.theme-option-hint{margin-top:.15rem;color:#778097;font:500 .68rem/1.1 var(--font-sans)}.theme-option-check{grid-column:2 / 3;grid-row:1 / 3;align-self:center;display:inline-flex;align-items:center;justify-content:center;color:#3e63c7;font-weight:700}.theme-option.is-selected{background:#ecf3ffc7;border-color:#abc4f5d1}.btn{border-radius:10px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.56rem 1.08rem;font:600 .88rem/1 var(--font-sans);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease,background-color .18s ease}.btn-primary{color:#fff;background:linear-gradient(180deg,var(--blue) 0%,var(--blue-dark) 100%);box-shadow:inset 0 1px #ffffff2e,0 10px 24px #2f80ff42}.btn-primary:hover{filter:brightness(1.06)}.btn-link{background:transparent;border-color:transparent;color:#2f2f2f;padding-inline:.25rem}.btn-ghost{color:#2f2f2f;background:#f8f8f8;border-color:#e1e1e1}.btn-ghost:hover,.btn-link:hover{transform:translateY(-1px)}.menu-trigger{display:none;border:1px solid #e4e4e4;background:#fff;border-radius:10px;padding:.45rem;color:#252525}.mobile-drawer-overlay{position:fixed;inset:0;z-index:60;background:#0e101457;display:flex;justify-content:flex-start}.mobile-drawer{width:min(84vw,340px);height:100%;border-right:1px solid #dfe2ea;background:#fbfcff;box-shadow:20px 0 36px #0000002e;padding:.85rem .7rem .75rem;display:flex;flex-direction:column}.mobile-drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.9rem}.mobile-close{border:0;background:transparent;color:#2e3442;width:26px;height:26px;border-radius:0;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.mobile-nav-links{display:grid;gap:.45rem;align-content:start}.mobile-nav-links a,.mobile-nav-links button{color:#313a48;background:transparent;border:0;text-align:left;width:100%;text-decoration:none;border-radius:10px;padding:.72rem .68rem;font:600 .88rem/1 var(--font-sans);cursor:pointer}.mobile-nav-links a:hover,.mobile-nav-links button:hover{background:#edf2ff}.mobile-theme-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.42rem}.mobile-drawer-footer{margin-top:auto;display:grid;gap:.62rem;padding-top:.8rem}.mobile-theme-pill{border-radius:10px;border:1px solid #e0e5f2;background:#f7f9ff;color:#2b3445;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.45rem .4rem;font:600 .78rem/1 var(--font-sans);cursor:pointer}.mobile-theme-pill.is-selected{border-color:#5b82ea;box-shadow:0 0 0 2px #5b82ea2e}.mobile-nav-cta{width:100%}.hero-section{flex:1;position:relative;display:grid;place-items:center;border-radius:18px;border:1px solid var(--panel-border);background:radial-gradient(circle at 1px 1px,#ebebeb 1px,transparent 0) 0 0 / 8px 8px,linear-gradient(180deg,#f7f7f7,#f3f3f3);min-height:0;overflow:hidden}.workspace-layer{position:absolute;inset:0;z-index:8;pointer-events:none}.workspace-window{position:absolute;min-width:min(88vw,280px);max-width:min(90vw,620px);min-height:220px;max-height:min(74vh,460px);border-radius:12px;border:1px solid rgb(215 219 228 / 72%);background:linear-gradient(180deg,#f8f9fcc2,#f2f4f8a8);box-shadow:0 20px 48px #0003;overflow:hidden;pointer-events:auto;touch-action:none;backdrop-filter:blur(12px) saturate(135%);-webkit-backdrop-filter:blur(12px) saturate(135%)}.workspace-window.is-maximized{resize:none;max-width:none;max-height:none}.workspace-window-about{max-width:min(94vw,760px);max-height:min(84vh,560px)}.workspace-window-projects{max-width:min(96vw,900px);max-height:min(88vh,620px)}.workspace-window-contact{max-width:min(96vw,920px);max-height:min(88vh,620px)}.workspace-window.is-minimized{height:34px!important}.workspace-window-bar{height:34px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.6rem;padding:0 .65rem;border-bottom:1px solid rgb(223 227 235 / 70%);background:linear-gradient(180deg,#f1f3f7d6,#e8ebf2b8);cursor:grab}.workspace-window-bar:active{cursor:grabbing}.workspace-window-controls{display:inline-flex;align-items:center;gap:.35rem}.window-dot{width:11px;height:11px;border-radius:999px;border:0;display:inline-block;padding:0;cursor:pointer}.window-dot-close{background:#ff5f57;cursor:pointer}.window-dot-minimize{background:#ffbd2e}.window-dot-expand{background:#28c840}.workspace-window-bar p{margin:0;text-align:center;color:#32384a;font:600 .78rem/1 var(--font-sans)}.workspace-window-body{height:calc(100% - 34px);overflow:auto;padding:.95rem 1rem;display:grid;gap:.58rem;container-type:inline-size;container-name:workspace-window;background:linear-gradient(180deg,#ffffff24,#ffffff0d);scrollbar-width:none;-ms-overflow-style:none;content-visibility:auto;contain-intrinsic-size:420px 320px}.workspace-window-body::-webkit-scrollbar{width:0;height:0;display:none}.workspace-window-loading{height:100%;width:100%;border-radius:8px;background:linear-gradient(110deg,#ffffff1a 25%,#ffffff38,#ffffff1a 55%);background-size:220% 100%;animation:workspace-loading 1.2s ease-in-out infinite}@keyframes workspace-loading{0%{background-position:100% 0}to{background-position:-100% 0}}.workspace-window-body p{margin:0;color:#3f4657;font:500 .92rem/1.3 var(--font-sans)}.workspace-resize-handle{position:absolute;z-index:5}.workspace-resize-handle-n,.workspace-resize-handle-s{left:14px;right:14px;height:10px}.workspace-resize-handle-n{top:-5px;cursor:ns-resize}.workspace-resize-handle-s{bottom:-5px;cursor:ns-resize}.workspace-resize-handle-e,.workspace-resize-handle-w{top:14px;bottom:14px;width:10px}.workspace-resize-handle-e{right:-5px;cursor:ew-resize}.workspace-resize-handle-w{left:-5px;cursor:ew-resize}.workspace-resize-handle-ne,.workspace-resize-handle-nw,.workspace-resize-handle-se,.workspace-resize-handle-sw{width:14px;height:14px}.workspace-resize-handle-ne{top:-6px;right:-6px;cursor:nesw-resize}.workspace-resize-handle-nw{top:-6px;left:-6px;cursor:nwse-resize}.workspace-resize-handle-se{right:-6px;bottom:-6px;cursor:nwse-resize}.workspace-resize-handle-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.about-window-layout{height:100%;display:grid;grid-template-columns:minmax(160px,210px) 1fr;gap:.9rem}.about-sidebar{border-radius:11px;border:1px solid rgb(223 227 235 / 78%);background:linear-gradient(180deg,#f6f8fcc7,#f1f4f9ad);padding:.9rem;display:grid;align-content:start;gap:.72rem}.about-avatar{width:82px;height:82px;border-radius:999px;object-fit:cover;border:2px solid rgb(255 255 255 / 85%);box-shadow:0 8px 18px #00000029}.about-sidebar-head h3{margin:0;color:#202638;font:700 1rem/1.2 var(--font-sans)}.about-sidebar-head p{margin:.2rem 0 0;color:#5d6475;font:600 .76rem/1.2 var(--font-sans)}.about-quick-facts{margin:0;padding:0;list-style:none;display:grid;gap:.65rem}.about-quick-facts li{display:grid;gap:.2rem}.about-quick-facts span{color:#798095;font:600 .68rem/1 var(--font-sans);text-transform:uppercase;letter-spacing:.06em}.about-quick-facts strong{color:#222938;font:600 .78rem/1.25 var(--font-sans)}.about-main{min-width:0;display:grid;grid-template-rows:auto 1fr;gap:.75rem}.about-tabs{display:flex;flex-wrap:wrap;gap:.45rem;border-bottom:1px solid rgb(218 224 233 / 76%);padding-bottom:.45rem}.about-tab{border:1px solid transparent;border-radius:10px;background:transparent;color:#4a5264;font:600 .76rem/1 var(--font-sans);padding:.38rem .62rem;cursor:pointer;transition:border-color .14s ease,background-color .14s ease,color .14s ease}.about-tab:hover{border-color:#c6cedbc7;background:#f3f6fba6}.about-tab.is-active{border-color:#89aaecb8;background:#e0ebffbd;color:#2f58a8}.about-panel{min-height:0;overflow:auto;border-radius:11px;border:1px solid rgb(222 227 236 / 74%);background:linear-gradient(180deg,#f8fafdd1,#f3f6fbad);padding:.82rem;display:grid;align-content:start;gap:.55rem;scrollbar-width:none;-ms-overflow-style:none}.about-panel::-webkit-scrollbar{width:0;height:0;display:none}.about-panel h4{margin:0;color:#212939;font:700 .92rem/1.2 var(--font-sans)}.about-panel h5{margin:0;color:#232c3e;font:700 .82rem/1.2 var(--font-sans)}.about-panel p{margin:0;color:#4a5366;font:500 .8rem/1.4 var(--font-sans)}.about-timeline{display:grid;gap:.55rem}.about-timeline-item{border-radius:10px;border:1px solid rgb(216 223 236 / 80%);background:#ffffff8c;padding:.65rem;display:grid;gap:.28rem}.about-timeline-item span{color:#63708a;font:700 .66rem/1 var(--font-sans);letter-spacing:.03em;text-transform:uppercase}.about-interest-tags{display:flex;flex-wrap:wrap;gap:.42rem}.about-interest-tags span{border-radius:999px;border:1px solid rgb(210 219 233 / 82%);background:#f7faffb8;color:#3a4f80;font:600 .72rem/1 var(--font-sans);padding:.4rem .58rem}.about-social-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem}.about-social-grid a{border-radius:10px;border:1px solid rgb(213 221 236 / 80%);background:#ffffff8f;padding:.62rem;text-decoration:none;display:grid;gap:.22rem;transition:transform .14s ease,border-color .14s ease,background-color .14s ease}.about-social-grid a:hover{transform:translateY(-1px);border-color:#8cacedc2;background:#e7f0ffad}.about-social-grid span{color:#2a3550;font:700 .76rem/1.1 var(--font-sans)}.about-social-title{display:inline-flex;align-items:center;gap:.45rem}.about-social-icon{display:inline-flex;align-items:center;justify-content:center}.about-social-icon svg{width:.9rem;height:.9rem}.about-social-linkedin{color:#0a66c2}.about-social-github{color:#222a3b}.about-social-youtube{color:red}.about-social-instagram{color:#d63f82}.about-social-grid strong{color:#60709a;font:600 .66rem/1 var(--font-sans)}.projects-window{min-height:100%;display:grid;align-content:start;gap:.72rem;padding-bottom:.75rem}.projects-intro{padding:.82rem;display:grid;gap:.42rem}.projects-intro h4{margin:0;color:#20283a;font:700 .95rem/1.2 var(--font-sans)}.projects-intro p{margin:0;color:#4a5367;font:500 .8rem/1.4 var(--font-sans);max-width:65ch}.project-bento-grid{min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.62rem;padding-bottom:1rem}.project-bento-card{border-radius:11px;border:1px solid rgb(219 225 236 / 80%);background:linear-gradient(180deg,#f8fafed6,#f3f7fdad);padding:.5rem;text-align:left;display:grid;gap:.52rem;cursor:pointer;transition:border-color .16s ease,background-color .16s ease,transform .16s ease}.project-bento-card:hover{border-color:#b8c6dfcc;background:#f1f6feb8;transform:translateY(-1px)}.project-bento-thumb{border-radius:10px;background:linear-gradient(180deg,#eff5ffc2,#e4eeffa8);aspect-ratio:16 / 10;overflow:hidden;display:grid;place-items:center;padding:0}.project-bento-thumb img{width:100%;height:100%;object-fit:cover}.project-bento-thumb span{color:#325187;font:700 .72rem/1.2 var(--font-sans);text-align:center}.project-bento-meta{display:grid;gap:.22rem}.project-bento-meta span{color:#6a7794;font:700 .62rem/1 var(--font-sans);letter-spacing:.04em;text-transform:uppercase}.project-bento-meta strong{color:#2a354b;font:700 .76rem/1.3 var(--font-sans)}.project-detail-view{min-height:0;display:grid;align-content:start;gap:.54rem;margin-bottom:.9rem}.projects-window.is-detail{border-radius:11px;background:linear-gradient(180deg,#f9fbffd1,#f3f7fca8);padding:.72rem}.projects-window.is-detail .project-detail-view{margin-bottom:0}.projects-window.is-detail .project-story-card{border:0;background:transparent;padding:0}.project-back-button{width:fit-content;border:none;border-radius:10px;background:transparent;color:#2d4578;padding:.38rem .54rem;display:inline-flex;align-items:center;gap:.36rem;font:700 .72rem/1 var(--font-sans);cursor:pointer;transition:border-color .14s ease,background-color .14s ease}.project-back-button svg{flex:0 0 auto}.project-back-button:hover{border-color:#93b0e9c7;background:#e6f0ffbf}.project-story-card{border-radius:11px;border:1px solid rgb(218 224 236 / 78%);background:linear-gradient(180deg,#f9fbffd1,#f3f7fca8);padding:.72rem .72rem 2rem;display:grid;align-content:start;gap:.58rem;overflow:visible}.project-story-image{width:100%;height:148px;border-radius:10px;object-fit:cover;border:1px solid rgb(208 218 235 / 82%)}.project-story-links{display:flex;flex-wrap:wrap;gap:.45rem}.project-story-links a{border-radius:999px;border:1px solid rgb(183 201 234 / 84%);background:#eaf2ffb8;color:#2e5498;text-decoration:none;font:700 .66rem/1 var(--font-sans);padding:.34rem .56rem}.project-story-head span{color:#667493;font:700 .63rem/1 var(--font-sans);letter-spacing:.045em;text-transform:uppercase}.project-story-head h5{margin:.22rem 0 0;color:#1f2a3e;font:700 .85rem/1.3 var(--font-sans)}.project-story-block{display:grid;gap:.28rem}.project-story-block h6{margin:0;color:#2e3f66;font:700 .68rem/1 var(--font-sans);letter-spacing:.04em;text-transform:uppercase}.project-story-block p{margin:0;color:#4a5367;font:500 .76rem/1.4 var(--font-sans)}.project-tech-grid{display:flex;flex-wrap:wrap;gap:.35rem}.project-tech-grid span{border-radius:999px;border:1px solid rgb(205 215 231 / 84%);background:#f5f9ffb8;color:#355084;font:600 .68rem/1 var(--font-sans);padding:.32rem .52rem}.project-story-block ul{margin:0;padding-left:1rem;display:grid;gap:.26rem}.project-story-block li{color:#4a5367;font:500 .74rem/1.35 var(--font-sans)}.contact-window{height:100%;min-height:0;display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:.7rem}.contact-side{border-radius:12px;border:1px solid rgb(218 224 235 / 80%);background:linear-gradient(180deg,#f8fafed6,#f3f7fdad);padding:.8rem;display:grid;align-content:start;gap:.5rem}.contact-chip{width:fit-content;border-radius:999px;margin-top:.5rem;color:#304f8f;font:700 .65rem/1 var(--font-sans);letter-spacing:.04em;text-transform:uppercase}.contact-side h4{margin:.1rem 0 0;color:#1f2a3d;font:700 1.1rem/1.2 var(--font-sans)}.contact-side>p{margin:0;color:#4e576b;font:500 .78rem/1.35 var(--font-sans)}.contact-cards{margin-top:.3rem;display:grid;gap:.5rem}.contact-card{border-radius:11px;border:1px solid rgb(214 221 234 / 80%);background:#fff9;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.55rem;padding:.55rem;text-decoration:none;transition:border-color .14s ease,transform .14s ease,background-color .14s ease}.contact-card:hover{border-color:#8babecbd;background:#e8f1ffb3;transform:translateY(-1px)}.contact-card-icon,.contact-card-arrow{width:1.7rem;height:1.7rem;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;color:#344f87}.contact-card-icon{border:1px solid rgb(205 214 230 / 82%)}.contact-card-icon svg,.contact-card-arrow svg{width:.95rem;height:.95rem}.contact-card-copy{display:grid;gap:.1rem}.contact-card-copy strong{color:#1f2a3d;font:700 .76rem/1.2 var(--font-sans)}.contact-card-copy small{color:#5a6680;font:600 .68rem/1.2 var(--font-sans)}.contact-form{min-height:0;border-radius:12px;border:1px solid rgb(214 221 234 / 80%);background:linear-gradient(180deg,#f8fafdd1,#f3f7fcab);padding:1.2rem .8rem;display:grid;grid-template-rows:auto auto auto auto;align-content:start;gap:.5rem}.contact-field{display:grid;gap:.25rem}.contact-field span{color:#4d5870;font:700 .66rem/1 var(--font-sans);letter-spacing:.03em;text-transform:uppercase}.contact-field input,.contact-field textarea{width:100%;border-radius:10px;border:1px solid rgb(201 210 226 / 82%);background:#ffffffbf;color:#1f2a3d;font:500 .8rem/1.35 var(--font-sans);padding:.58rem .65rem;outline:none}.contact-field textarea{resize:vertical}.contact-field.has-error input,.contact-field.has-error textarea{border-color:#ce5c5cdb;box-shadow:0 0 0 2px #ce5c5c24}.contact-field-error{margin:.06rem 0 0;color:#b04343;font:600 .66rem/1.25 var(--font-sans)}.contact-field input:focus,.contact-field textarea:focus{border-color:#7ca0e7db;box-shadow:0 0 0 2px #7ca0e72e}.contact-submit{border:1px solid rgb(177 196 231 / 82%);border-radius:10px;background:linear-gradient(180deg,#347cf4eb,#1f65dce5);color:#fff;font:700 .8rem/1 var(--font-sans);padding:.62rem .72rem;display:inline-flex;align-items:center;justify-content:center;align-self:start;gap:.42rem;cursor:pointer;transition:filter .14s ease,transform .14s ease}.contact-submit:hover{filter:brightness(1.06);transform:translateY(-1px)}.contact-submit-icon{transition:transform .14s ease}.contact-submit.is-loading .contact-submit-icon{animation:contact-send-pulse .85s ease-in-out infinite}.contact-submit:disabled{opacity:.74;cursor:not-allowed;transform:none;filter:none}.contact-submit-message{margin:0;font:600 .7rem/1.3 var(--font-sans)}.contact-submit-message.is-submitting{color:#3f5a8f}.contact-submit-message.is-success{color:#16784a}.contact-submit-message.is-error{color:#a63333}.contact-success-toast{margin-top:.1rem;border:1px solid rgb(117 194 157 / 70%);background:#d3f6e6b8;color:#176243;border-radius:10px;padding:.48rem .56rem;display:inline-flex;align-items:center;gap:.4rem;font:600 .7rem/1.25 var(--font-sans)}.contact-success-toast-icon{flex:0 0 auto}@keyframes contact-send-pulse{0%,to{transform:translate(0)}50%{transform:translate(1px)}}.workspace-window.is-minimized .workspace-window-body{display:none}@container workspace-window (max-width: 480px){.about-window-layout{grid-template-columns:1fr}.about-sidebar{grid-template-columns:auto 1fr;align-items:center;gap:.7rem}.about-sidebar-head{align-self:center}.about-quick-facts{grid-column:1 / -1}.about-social-grid,.project-bento-grid{grid-template-columns:1fr}.project-bento-thumb{aspect-ratio:16 / 10}.project-story-card{overflow:visible}.contact-window{grid-template-columns:1fr}.contact-form{grid-template-columns:1fr;gap:.58rem}.contact-field textarea{min-height:130px}.contact-submit{width:100%;align-self:stretch}.contact-submit-message,.contact-success-toast{width:100%}}@container workspace-window (max-width: 360px){.about-panel,.projects-intro,.project-story-card,.project-bento-card,.contact-side,.contact-form{padding:.68rem}.about-tab{font-size:.72rem;padding:.34rem .54rem}.project-story-image{height:128px}.project-bento-thumb{aspect-ratio:16 / 10}.project-back-button{padding:.34rem .48rem;font-size:.68rem}.contact-card{grid-template-columns:auto 1fr}.contact-card-arrow{display:none}.contact-field span{font-size:.62rem}.contact-field input,.contact-field textarea,.contact-submit{font-size:.76rem}.contact-field textarea{min-height:112px}}[data-theme=dark] .hero-frame{border-color:#2f3239}[data-theme=dark] .top-nav-links a,[data-theme=dark] .top-nav-links button{color:#ced3db}[data-theme=dark] .top-nav-links a:hover,[data-theme=dark] .top-nav-links button:hover{color:#fff}[data-theme=dark] .btn-ghost,[data-theme=dark] .theme-trigger{background:#2c2f35;border-color:#3c4048;color:#e6e9ee;box-shadow:0 0 0 2px #42485840}[data-theme=dark] .menu-trigger{background:#2c2f35;border-color:#3c4048;color:#e6e9ee}[data-theme=dark] .btn-link{color:#e6e9ee}[data-theme=dark] .theme-option-hint{color:#a3abbb}[data-theme=dark] .theme-trigger-chevron{color:#bcc2cf}[data-theme=dark] .theme-panel{background:linear-gradient(180deg,#2a2e36c7,#252932ad);border-color:#4e5667b3;box-shadow:0 16px 36px #00000057;backdrop-filter:blur(10px) saturate(132%);-webkit-backdrop-filter:blur(10px) saturate(132%)}[data-theme=dark] .theme-option{background:#ffffff0d;color:#eceff4}[data-theme=dark] .theme-option:hover{background:#ffffff1c;border-color:#626c80c7}[data-theme=dark] .theme-option.is-selected{background:#7088bb40;border-color:#7e98d094}[data-theme=dark] .theme-option-check{color:#9ab5ff}[data-theme=dark] .hero-section{background:radial-gradient(circle at 1px 1px,#343842 1px,transparent 0) 0 0 / 8px 8px,linear-gradient(180deg,#24272c,#212329)}[data-theme=dark] .hero-avatar-tooltip{background:#f3f6fc;color:#1c2231;box-shadow:0 12px 26px #03060a4d}[data-theme=dark] .hero-avatar-tooltip:after{border-top-color:#f3f6fc}[data-theme=dark] .workspace-window{border-color:#4e5667b3;background:linear-gradient(180deg,#2a2e36bd,#252932a3);box-shadow:0 20px 48px #0006}[data-theme=dark] .workspace-window-bar{border-bottom-color:#414653b8;background:linear-gradient(180deg,#333844d1,#2b303bb3)}[data-theme=dark] .workspace-window-bar p{color:#e8ebf2}[data-theme=dark] .workspace-window-body p{color:#cdd2df}[data-theme=dark] .workspace-window-body{background:linear-gradient(180deg,#080a0d38,#080a0d1a)}[data-theme=dark] .about-sidebar{border-color:#454d5cbd;background:linear-gradient(180deg,#2d313abf,#272b33a8)}[data-theme=dark] .about-sidebar-head h3{color:#edf0f6}[data-theme=dark] .about-sidebar-head p,[data-theme=dark] .about-quick-facts span{color:#aeb6c7}[data-theme=dark] .about-quick-facts strong{color:#dbe2ef}[data-theme=dark] .about-tabs{border-bottom-color:#4c5463bd}[data-theme=dark] .about-tab{color:#c7cfde}[data-theme=dark] .about-tab:hover{border-color:#576277b8;background:#343a46b8}[data-theme=dark] .about-tab.is-active{border-color:#7494d6c2;background:#34486fbd;color:#d9e7ff}[data-theme=dark] .about-panel{border-color:#424a59bf;background:linear-gradient(180deg,#282d36c7,#222731a8)}[data-theme=dark] .about-panel h4,[data-theme=dark] .about-panel h5{color:#edf1f9}[data-theme=dark] .about-panel p{color:#c9d1df}[data-theme=dark] .about-timeline-item{border-color:#485162bd;background:#222731a8}[data-theme=dark] .about-timeline-item span{color:#9eb2d8}[data-theme=dark] .about-interest-tags span{border-color:#485265c2;background:#2b313dbd;color:#c8dafd}[data-theme=dark] .about-social-grid a{border-color:#485162bd;background:#252a34b8}[data-theme=dark] .about-social-grid a:hover{border-color:#708fd0c7;background:#314162b3}[data-theme=dark] .about-social-grid span{color:#dbe5f8}[data-theme=dark] .about-social-github{color:#e6ecf8}[data-theme=dark] .about-social-instagram{color:#f07cb1}[data-theme=dark] .about-social-grid strong{color:#9db1da}[data-theme=dark] .projects-intro h4{color:#edf1f9}[data-theme=dark] .projects-intro p{color:#c5cfde}[data-theme=dark] .project-story-card{border-color:#475163c2;background:linear-gradient(180deg,#292e39c4,#222731a8)}[data-theme=dark] .projects-window.is-detail{background:linear-gradient(180deg,#292e39c4,#222731a8)}[data-theme=dark] .project-bento-card{border-color:#475163c2;background:linear-gradient(180deg,#2b303ac4,#242933a8)}[data-theme=dark] .project-bento-card:hover{border-color:#5a687fcc;background:#323a48b8}[data-theme=dark] .project-bento-thumb{background:linear-gradient(180deg,#303846c2,#2a313ead)}[data-theme=dark] .project-bento-thumb span{color:#bdd2ff}[data-theme=dark] .project-bento-meta span{color:#9db1d8}[data-theme=dark] .project-bento-meta strong{color:#d8e2f4}[data-theme=dark] .project-back-button{color:#d8e5ff}[data-theme=dark] .project-back-button:hover{border-color:#87a5e2c7;background:#3d5481a8}[data-theme=dark] .project-story-head span{color:#9db1d8}[data-theme=dark] .project-story-head h5{color:#e4ebf8}[data-theme=dark] .project-story-block h6{color:#bdd2ff}[data-theme=dark] .project-story-block p,[data-theme=dark] .project-story-block li{color:#c5cfde}[data-theme=dark] .project-tech-grid span{border-color:#495468cc;background:#2b323fc2;color:#c4d8ff}[data-theme=dark] .contact-side{border-color:#464f60c2;background:linear-gradient(180deg,#2c313bc4,#252a34a8)}[data-theme=dark] .contact-chip{border-color:#56688ec7;background:#324366bd;color:#d4e2ff}[data-theme=dark] .contact-side h4,[data-theme=dark] .contact-card-copy strong{color:#e5ecf8}[data-theme=dark] .contact-side>p,[data-theme=dark] .contact-card-copy small,[data-theme=dark] .contact-field span{color:#bcc8dc}[data-theme=dark] .contact-card{border-color:#465162c7;background:#252b35b8}[data-theme=dark] .contact-card:hover{border-color:#708fd0c7;background:#314262b8}[data-theme=dark] .contact-card-icon,[data-theme=dark] .contact-card-arrow{border-color:#505c71cc;color:#c8d8fa}[data-theme=dark] .contact-form{border-color:#464f60c2;background:linear-gradient(180deg,#292e39c4,#222731a8)}[data-theme=dark] .contact-field input,[data-theme=dark] .contact-field textarea{border-color:#505c71cc;background:#242a34c7;color:#edf2fb}[data-theme=dark] .contact-field.has-error input,[data-theme=dark] .contact-field.has-error textarea{border-color:#d26e6ed1;box-shadow:0 0 0 2px #d26e6e2e}[data-theme=dark] .contact-field-error{color:#f2a2a2}[data-theme=dark] .contact-submit{border-color:#5279cad1;background:linear-gradient(180deg,#4481e9eb,#326dd2e5)}[data-theme=dark] .contact-submit-message.is-submitting{color:#a9c0ee}[data-theme=dark] .contact-submit-message.is-success{color:#75d6aa}[data-theme=dark] .contact-submit-message.is-error{color:#f09c9c}[data-theme=dark] .contact-success-toast{border-color:#58a77fbf;background:#264d3ea6;color:#b8efd4}[data-theme=dark] .project-story-image{border-color:#4b566ccc}[data-theme=dark] .project-story-links a{border-color:#546a93d1;background:#334362b8;color:#cce0ff}[data-theme=dark] .reminder-card,[data-theme=dark] .tasks-card,[data-theme=dark] .integrations-card{border-color:#6f768470;background:linear-gradient(180deg,#313640b8,#282c3599)}[data-theme=dark] .card-label,[data-theme=dark] .card-title,[data-theme=dark] .tasks-header p,[data-theme=dark] .integrations-card p{color:#eef2f8}[data-theme=dark] .card-subtitle,[data-theme=dark] .reminder-head span,[data-theme=dark] .task-line,[data-theme=dark] .task-date{color:#bcc4d4}[data-theme=dark] .tasks-header{color:#dbe1ec}[data-theme=dark] .progress-rail{background:#3f4656}[data-theme=dark] .reminder-time{border-color:#5f7fa76b;background:#293f607a;color:#b6d6ff}[data-theme=dark] .sticky-note-card{border-color:#fff4b185;background:linear-gradient(160deg,#f6ea93c7,#efe184b3 64%,#e7d67aa8);color:#171717}[data-theme=dark] .sticky-action{border-color:#79a6ff75;background:linear-gradient(180deg,#4270c4b3,#2e539d99)}[data-theme=dark] .reminder-clock{border-color:#5c6a887f;background:linear-gradient(180deg,#3a4356b8,#313a4b9e);color:#dbe2f0}[data-theme=dark] .integration-tile{border-color:#5a62728a;background:linear-gradient(180deg,#3e4554b8,#353b489e);color:#d8deea}[data-theme=dark] .mobile-drawer-overlay{background:#0405088f}[data-theme=dark] .mobile-drawer{background:#2b2e35;border-color:#3f434d;box-shadow:20px 0 36px #00000070}[data-theme=dark] .mobile-close{background:transparent;color:#e9edf4}[data-theme=dark] .mobile-nav-links a,[data-theme=dark] .mobile-nav-links button{color:#e8ebf1}[data-theme=dark] .mobile-nav-links a:hover,[data-theme=dark] .mobile-nav-links button:hover{background:#363b47}[data-theme=dark] .mobile-theme-pill{background:#333843;border-color:#464c58;color:#e6eaf1}[data-theme=dark] .mobile-theme-pill.is-selected{border-color:#86a7ff;box-shadow:0 0 0 2px #86a7ff33}.hero-content{position:relative;z-index:2;width:min(720px,100%);max-width:720px;margin:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:clamp(2.2rem,6vw,5.1rem) 1.25rem}.icon-cluster{width:100px;height:100px;position:relative;margin-bottom:1.9rem}.icon-cluster img{width:100%;height:100%;object-fit:contain}.hero-avatar-trigger{cursor:default}.hero-avatar-trigger:focus-visible{outline:2px solid rgb(60 130 255 / 70%);outline-offset:7px;border-radius:16px}.hero-avatar-tooltip{position:absolute;left:50%;bottom:calc(100% + .8rem);transform:translate(-50%) translateY(8px);min-width:168px;padding:.72rem .95rem .68rem;border-radius:16px;background:#191b22;color:#f2f5fb;box-shadow:0 12px 26px #0a0c1147;text-align:left;pointer-events:none;opacity:0;visibility:hidden;transform-origin:50% 100%}.hero-avatar-tooltip:after{content:"";position:absolute;left:50%;top:100%;width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-top:10px solid #191b22;transform:translate(-50%)}.hero-avatar-tooltip strong,.hero-avatar-tooltip small{display:block}.hero-avatar-tooltip strong{font:600 1rem/1.08 var(--font-sans);letter-spacing:-.01em}.hero-avatar-tooltip small{margin-top:.3rem;font:500 .79rem/1.16 var(--font-sans);opacity:.86}.hero-avatar-trigger:hover .hero-avatar-tooltip,.hero-avatar-trigger:focus-visible .hero-avatar-tooltip{visibility:visible;opacity:1;transform:translate(-50%) translateY(0);animation:hero-tooltip-tilt .72s cubic-bezier(.21,.89,.36,1.05) 1}@keyframes hero-tooltip-tilt{0%{transform:translate(-50%) translateY(6px) rotate(0)}25%{transform:translate(-50%) translateY(1px) rotate(-9deg)}52%{transform:translate(-50%) translateY(0) rotate(8deg)}72%{transform:translate(-50%) translateY(0) rotate(-4deg)}to{transform:translate(-50%) translateY(0) rotate(0)}}.hero-content h1{margin:0;color:var(--text);font:650 clamp(2rem,5.6vw,4.2rem) / 1.06 var(--font-sans);letter-spacing:-.026em}.hero-content h1 span{display:block;color:#9c9c9c;font-weight:430}.hero-content p{margin:1rem 0 1.7rem;font:500 clamp(.92rem,1.5vw,1.08rem) / 1.3 var(--font-sans);color:#606060}.hero-cta{padding:.76rem 1.26rem;font-size:.92rem}.floating-card{position:absolute;z-index:1;border-radius:20px;box-shadow:var(--card-shadow);backdrop-filter:blur(10px) saturate(132%);-webkit-backdrop-filter:blur(10px) saturate(132%);will-change:transform;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none}.floating-card:active{cursor:grabbing}.sticky-note-card{top:2.95rem;left:1rem;width:196px;min-height:160px;border:1px solid rgb(255 246 189 / 72%);background:linear-gradient(160deg,#f6ea93db,#efe184c7 64%,#e7d67ab8);padding:.9rem .82rem .82rem;font:600 .8rem/1.2 var(--font-sans);color:#232323;backdrop-filter:blur(8px) saturate(128%);-webkit-backdrop-filter:blur(8px) saturate(128%)}.pin-head{position:absolute;left:54%;top:-11px;width:15px;aspect-ratio:1;border-radius:999px;background:#d42f43;box-shadow:0 3px #ac1b2d}.pin-icon{position:absolute;left:calc(54% - 6px);top:-2px;color:#fff}.sticky-action{position:absolute;left:50%;bottom:-1rem;transform:translate(-50%);width:58px;height:58px;border-radius:18px;display:grid;place-items:center;border:1px solid rgb(167 211 255 / 68%);background:linear-gradient(180deg,#3f91ffb8,#1869eaa3);box-shadow:var(--card-shadow);backdrop-filter:blur(10px) saturate(132%);-webkit-backdrop-filter:blur(10px) saturate(132%)}.reminder-card{top:2.35rem;right:.85rem;width:212px;padding:.8rem .78rem;border:1px solid rgb(255 255 255 / 62%);background:linear-gradient(175deg,#f8f8f8c7,#ececec94)}.reminder-clock{position:absolute;left:-17px;top:21px;width:41px;height:41px;border-radius:999px;border:1px solid rgb(233 239 250 / 72%);display:grid;place-items:center;background:linear-gradient(180deg,#ffffffbd,#eef4ffa3);color:#3c465b;backdrop-filter:blur(8px) saturate(130%);-webkit-backdrop-filter:blur(8px) saturate(130%)}.reminder-head{display:flex;align-items:baseline;justify-content:space-between}.reminder-head span{font:600 .68rem/1 var(--font-sans);color:#ababab}.card-label{margin:0;font:700 .92rem/1.2 var(--font-sans);color:#222}.card-title{margin:.8rem 0 .12rem;font:700 .8rem/1.2 var(--font-sans);color:#1f1f1f}.card-subtitle{margin:0;font:500 .72rem/1.3 var(--font-sans);color:#7a7a7a}.reminder-time{margin-top:.66rem;border-radius:10px;border:1px solid #d8eff8;background:#ecfaff;display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .5rem;color:#14798d;font:700 .68rem/1 var(--font-sans)}.tasks-card{left:1rem;bottom:-2.2rem;width:252px;border:1px solid rgb(255 255 255 / 58%);background:linear-gradient(180deg,#f7f7f7c7,#ececec94);padding:1rem}.tasks-header{display:flex;align-items:center;gap:.5rem;color:#333}.tasks-header p{margin:0;font:700 .84rem/1 var(--font-sans)}.task-row{margin-top:.75rem}.task-line{display:flex;justify-content:space-between;gap:.8rem;font:600 .68rem/1.2 var(--font-sans);color:#575757}.task-date{display:inline-block;margin-top:.33rem;font:500 .58rem/1.1 var(--font-sans);color:#9b9b9b}.progress-rail{margin-top:.25rem;height:5px;border-radius:999px;background:#e0e0e0;overflow:hidden}.progress-rail span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#17b5eb,#2e77ff)}.integrations-card{right:1.45rem;bottom:-2.2rem;width:214px;border:1px solid rgb(255 255 255 / 58%);background:linear-gradient(180deg,#f7f7f7c7,#ececec94);padding:.86rem}.integrations-card p{margin:0 0 .65rem;font:700 .8rem/1.2 var(--font-sans);color:#1f1f1f}.integration-icons{display:flex;gap:.62rem}.integration-tile{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(180deg,#ffffffb8,#f3f6fc94);border:1px solid rgb(234 238 246 / 78%);color:#3f495f;backdrop-filter:blur(8px) saturate(125%);-webkit-backdrop-filter:blur(8px) saturate(125%);transition:transform .18s ease,box-shadow .18s ease}.integration-tile:hover{transform:translateY(-2px);box-shadow:0 8px 14px #0000001a}@media(max-width:960px){.top-nav-links,.top-nav-actions .btn-primary,.top-nav-actions .btn-ghost,.top-nav-actions .theme-picker{display:none}.menu-trigger{display:inline-flex}.hero-section,.hero-content{min-height:100%}.sticky-note-card,.reminder-card,.tasks-card,.integrations-card{display:none}.sticky-note-card{width:178px;min-height:194px;font-size:.96rem}.reminder-card{width:190px}.hero-content{width:min(680px,100%);padding:1.2rem}}@media(max-width:760px){.app-shell{padding:0}.hero-frame{height:var(--viewport-h);min-height:var(--viewport-h);padding:.55rem}.top-nav{padding:.3rem .6rem .75rem}.brand{gap:.58rem}.brand-name{font-size:.84rem}.brand-role{font-size:.52rem}.hero-section,.hero-content{min-height:100%}.hero-content{padding:1.1rem}.hero-content h1{font-size:clamp(1.7rem,8.2vw,2.5rem);font-weight:620;letter-spacing:-.018em}.hero-content h1 span{margin-top:.22rem;font-weight:430}.hero-content p{font-size:clamp(.9rem,3.5vw,.98rem);margin:.8rem 0 1.35rem}.sticky-note-card,.reminder-card,.tasks-card,.integrations-card{display:none}.workspace-window{max-width:calc(100% - .75rem);max-height:calc(100% - .75rem);min-width:250px;min-height:200px}}@media(min-width:961px)and (max-height:860px)and (min-aspect-ratio:16 / 10){.hero-frame{padding:.55rem}.top-nav{padding:.32rem .8rem .6rem}.brand{gap:.62rem}.brand-name{font-size:.9rem}.brand-role{font-size:.56rem}.hero-content{padding:clamp(1rem,3.2vh,1.8rem) 1rem;width:min(660px,100%)}.icon-cluster{width:66px;height:66px;margin-bottom:1rem}.cluster-dot{width:13px}.hero-content h1{font-size:clamp(1.72rem,4.1vw,2.75rem);line-height:1.04}.hero-content p{margin:.62rem 0 1rem;font-size:clamp(.86rem,1.1vw,.98rem);line-height:1.24}.hero-cta{padding:.64rem 1.08rem;font-size:.84rem}}@media(min-width:1200px)and (max-height:720px){.hero-content{padding-block:.75rem}.hero-content h1{font-size:clamp(1.55rem,3.3vw,2.2rem)}}@media(max-width:540px){.hero-content{min-height:100%;justify-content:center;padding:1rem}.icon-cluster{margin-bottom:1.5rem;width:70px;height:70px}.cluster-dot{width:14px}.hero-content h1{font-size:clamp(1.45rem,9.8vw,2.05rem);font-weight:600;line-height:1.12;letter-spacing:-.012em}.hero-content h1 span{font-size:.9em;margin-top:.28rem}.hero-content p{font-size:.88rem;line-height:1.28;margin:.72rem 0 1.2rem}.tasks-card{width:calc(100% - 1.3rem);left:.65rem;bottom:.7rem;transform:none}.integrations-card{left:.65rem;width:auto;right:.65rem}}
