@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--cream: #FAF7F2;--ink: #1A2744;--cobalt: #2E5EF5;--pink: #F0527A;--cloud: #FFFFFF;--steel: #5A7BA8;--ink-rgb: 26, 39, 68;--cobalt-rgb: 46, 94, 245;--pink-rgb: 240, 82, 122;--bg-primary: #FAF7F2;--bg-surface: #FFFFFF;--bg-elevated: rgba(250, 247, 242, .85);--bg-tint: rgba(46, 94, 245, .05);--border: rgba(26, 39, 68, .12);--border-subtle: rgba(26, 39, 68, .06);--border-accent: rgba(240, 82, 122, .4);--text-primary: #1A2744;--text-secondary: #5A7BA8;--text-muted: rgba(90, 123, 168, .6);--text-inverse: #FFFFFF;--accent-blue: #2E5EF5;--accent-blue-hover: #1A4AD4;--accent-pink: #F0527A;--accent-pink-hover: #D63D64;--shadow-sm: 0 1px 4px rgba(26, 39, 68, .08);--shadow-md: 0 4px 16px rgba(26, 39, 68, .1);--shadow-lg: 0 8px 32px rgba(26, 39, 68, .12);--shadow-float: 0 8px 40px rgba(26, 39, 68, .14);--font-display: "DM Serif Display", Georgia, serif;--font-primary: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Courier New", monospace;--t-xs: .75rem;--t-sm: .875rem;--t-base: 1rem;--t-lg: 1.25rem;--t-xl: 1.75rem;--t-2xl: 2.5rem;--t-3xl: 3.5rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--max-width: 1100px;--page-padding: clamp(1.5rem, 5vw, 4rem);--section-gap: 7.5rem;--section-gap-sm: 5rem;--transition: .2s ease;--primary-color: var(--accent-blue);--light-bg: var(--bg-primary);--border-color: var(--border)}html{scroll-behavior:smooth}body{font-family:var(--font-primary);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#1a274426;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-pink)}h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:1.25;color:var(--text-primary);margin-bottom:.75rem}h5,h6{font-family:var(--font-primary);font-weight:600;line-height:1.25;color:var(--text-primary);margin-bottom:.75rem}h1{font-size:clamp(2rem,5vw,var(--t-3xl))}h2{font-size:clamp(1.5rem,3vw,var(--t-2xl))}h3{font-size:var(--t-xl)}h4{font-size:var(--t-lg)}p{color:var(--text-secondary);margin-bottom:1rem;font-weight:400;line-height:1.7}a{color:var(--accent-blue);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--accent-blue-hover)}.container{max-width:var(--max-width);margin:0 auto;padding:0 var(--page-padding)}.section{padding:var(--section-gap) 0}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-family:var(--font-primary);font-size:.9rem;font-weight:500;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;text-decoration:none;transition:all var(--transition);white-space:nowrap}.btn-primary{background:var(--accent-blue);color:var(--text-inverse);border-color:var(--accent-blue)}.btn-primary:hover{background:var(--accent-blue-hover);border-color:var(--accent-blue-hover);color:var(--text-inverse)}.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--ink)}.btn-outline:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:transparent}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{color:var(--accent-blue);background:var(--bg-tint)}.btn-danger{background:#f0527a1f;color:var(--accent-pink);border-color:transparent}.btn-danger:hover{background:#f0527a33}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);box-shadow:var(--shadow-sm)}.card:hover{border-color:var(--border-accent);background:var(--bg-tint);box-shadow:var(--shadow-md)}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in-up{animation:fadeInUp .5s ease-out}.fade-in{animation:fadeIn .5s ease-out}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{width:36px;height:36px;border:3px solid rgba(26,39,68,.1);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.container{padding:0 1rem}.section{padding:var(--section-gap-sm) 0}.grid{gap:1rem}}@media (max-width: 480px){.btn{padding:.5rem 1rem;font-size:.85rem}}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;justify-content:center;align-items:center;height:72px;padding:0 var(--page-padding);transition:top .4s cubic-bezier(.25,.46,.45,.94),padding .4s cubic-bezier(.25,.46,.45,.94)}.navbar.floating{top:.75rem;padding:0 clamp(1rem,4vw,2rem)}.nav-container{width:100%;max-width:var(--max-width);display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:0;background:transparent;border-radius:0;border:1px solid transparent;box-shadow:none;transition:max-width .4s cubic-bezier(.25,.46,.45,.94),padding .4s cubic-bezier(.25,.46,.45,.94),border-radius .4s cubic-bezier(.25,.46,.45,.94),background .35s ease,box-shadow .4s ease,border-color .35s ease}.navbar.floating .nav-container{max-width:700px;padding:.55rem 1.5rem;border-radius:999px;background:var(--bg-elevated);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-color:#1a27441a;box-shadow:var(--shadow-float)}.nav-logo{display:flex;align-items:center;text-decoration:none;font-family:var(--font-primary);font-weight:600;font-size:1rem;color:var(--text-primary);letter-spacing:-.02em;transition:opacity var(--transition);white-space:nowrap}.nav-logo:hover{opacity:.7;color:var(--text-primary)}.nav-menu{display:flex;align-items:center;gap:.125rem;list-style:none}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:var(--t-sm);padding:.4rem .75rem;border-radius:var(--radius-md);transition:color var(--transition)}.nav-link:hover{color:var(--accent-blue)}.nav-link.active{color:var(--text-primary);text-decoration:underline;text-decoration-color:var(--accent-pink);text-decoration-thickness:2px;text-underline-offset:4px}.nav-toggle{display:none;cursor:pointer;color:var(--text-primary);padding:.4rem;transition:opacity var(--transition);background:none;border:none}.nav-toggle:hover{opacity:.7}@media (max-width: 768px){.navbar{height:60px;padding:0 1rem;background:var(--bg-elevated);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.navbar.floating{top:0;padding:0 1rem}.navbar.floating .nav-container,.nav-container{max-width:none;padding:0;border-radius:0;background:transparent;border-color:transparent;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.nav-menu{position:fixed;top:60px;left:0;right:0;background:var(--bg-surface);flex-direction:column;padding:1rem 0 1.5rem;gap:0;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .25s ease;border-bottom:1px solid var(--border);box-shadow:var(--shadow-md)}.nav-menu.active{transform:translateY(0);opacity:1;visibility:visible}.nav-link{width:100%;text-align:center;padding:.875rem 2rem;border-radius:0;border-bottom:1px solid var(--border-subtle);font-size:.95rem}.nav-link:last-child{border-bottom:none}.nav-toggle{display:flex}}.side-stack-section,.side-stack-track{position:relative}.side-stack-card{position:sticky;top:10vh;max-width:760px;margin:0 auto 3rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:0;padding:2.5rem;box-shadow:none;transform-origin:top center;transition:transform .35s ease,opacity .35s ease;will-change:transform,opacity}.side-stack-card.receding{transform:scale(.95) translateY(-36px);opacity:.7}.side-stack-card.hidden{opacity:0;pointer-events:none}.ss-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.ss-title-block{flex:1}.ss-company{font-family:var(--font-primary);font-size:var(--t-lg);font-weight:600;color:var(--text-primary);margin-bottom:.2rem;display:flex;align-items:center;gap:.5rem}.ss-position{font-size:var(--t-base);color:var(--accent-blue);font-weight:500;margin-bottom:.2rem}.ss-location{font-size:var(--t-sm);color:var(--text-muted);display:flex;align-items:center;gap:.25rem}.ss-duration{font-size:var(--t-xs);color:var(--text-secondary);font-family:var(--font-mono);background:var(--bg-primary);border:1px solid var(--border);padding:.35rem .75rem;border-radius:var(--radius-sm);white-space:nowrap;align-self:flex-start}.ss-bullets{list-style:none;padding:0;margin:0}.ss-bullets li{position:relative;padding-left:1.25rem;margin-bottom:.6rem;color:var(--text-secondary);line-height:1.6;font-size:.9rem}.ss-bullets li:before{content:"▸";position:absolute;left:0;color:var(--accent-pink)}.ss-counter{font-size:var(--t-xs);color:var(--text-muted);font-family:var(--font-mono);text-align:center;padding:1.5rem 0;position:sticky;bottom:1rem}@media (max-width: 768px){.side-stack-card{top:4vh;padding:1.75rem 1.25rem}.ss-header{flex-direction:column}}.admin-login-input{font-size:1rem!important}@media (max-width: 480px){.admin-login-page{padding:2rem 1rem 1rem!important;align-items:flex-start!important}.admin-login-card{padding:1.75rem 1.25rem!important}}.admin-layout{display:flex;min-height:100vh;background:var(--bg-primary);font-family:var(--font-primary)}.admin-sidebar{width:220px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;transition:transform .25s ease;z-index:100}.admin-side-header{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--border-subtle)}.admin-nav{flex:1;padding:.75rem 0}.admin-logout{margin:1rem;padding:.6rem;background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:var(--t-xs);font-family:var(--font-primary);width:calc(100% - 2rem);transition:background var(--transition),color var(--transition)}.admin-logout:hover{background:#f0527a14;color:var(--accent-pink);border-color:var(--border-accent)}.admin-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:99}.admin-main{flex:1;display:flex;flex-direction:column;overflow:auto;min-width:0}.admin-topbar{background:var(--bg-surface);padding:1rem 2rem;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center;gap:1rem}.admin-hamburger{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.25rem .5rem;font-size:1.4rem;line-height:1;flex-shrink:0}.admin-content{padding:2rem;flex:1}.admin-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}@media (max-width: 768px){.admin-sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%)}.admin-sidebar.open{transform:translate(0);box-shadow:var(--shadow-lg)}.admin-overlay.open,.admin-hamburger{display:block}.admin-topbar{padding:.85rem 1rem}.admin-topbar-meta{display:none}.admin-content{padding:1rem}}.App{min-height:100vh;background:var(--bg-primary)}main{padding-top:72px}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:var(--bg-primary);overflow:hidden}.hero-content{text-align:center;max-width:780px;padding:2rem;z-index:2;position:relative}.hero-title{font-family:var(--font-display);font-size:var(--t-3xl);font-weight:400;letter-spacing:-.02em;margin-bottom:1rem;color:var(--text-primary);line-height:1.1}.hero-subtitle{font-size:var(--t-lg);color:var(--text-secondary);margin-bottom:1rem;font-weight:400}.hero-tagline{font-size:var(--t-sm);color:var(--text-muted);margin-bottom:2.5rem;font-family:var(--font-mono);letter-spacing:.02em}.hero-cta{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.section-header{text-align:center;margin-bottom:3rem}.section-title{font-family:var(--font-display);font-size:clamp(1.75rem,3.5vw,var(--t-2xl));font-weight:400;margin-bottom:.75rem;color:var(--text-primary);position:relative;display:inline-block}.section-title:after{content:"";display:block;width:40px;height:2px;background:var(--accent-pink);margin:.5rem auto 0}.section-subtitle{font-size:var(--t-base);color:var(--text-secondary);max-width:560px;margin:0 auto;line-height:1.6}.experience-card{background:var(--bg-surface);border:1px solid var(--border);border-left:4px solid var(--accent-pink);border-radius:var(--radius-lg);padding:1.75rem;position:relative;transition:border-color var(--transition),box-shadow var(--transition);box-shadow:var(--shadow-sm)}.experience-card:hover{border-color:var(--border-accent);border-left-color:var(--accent-pink-hover);box-shadow:var(--shadow-md)}.experience-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.experience-title{flex:1}.experience-company{font-family:var(--font-primary);font-size:var(--t-lg);font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.experience-position{font-size:var(--t-base);color:var(--accent-blue);margin-bottom:.2rem;font-weight:500}.experience-location{font-size:var(--t-sm);color:var(--text-muted)}.experience-duration{font-size:var(--t-xs);color:var(--text-secondary);font-family:var(--font-mono);background:var(--bg-surface);border:1px solid var(--border);padding:.35rem .75rem;border-radius:var(--radius-sm);white-space:nowrap}.experience-description{list-style:none;padding:0;margin-top:1rem}.experience-description li{position:relative;padding-left:1.25rem;margin-bottom:.6rem;color:var(--text-secondary);line-height:1.6;font-size:.9rem}.experience-description li:before{content:"▸";position:absolute;left:0;color:var(--accent-pink)}.blog-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);cursor:pointer;height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.blog-card:hover{border-color:var(--border-accent);background:var(--bg-tint);box-shadow:var(--shadow-md)}.blog-title{font-family:var(--font-primary);font-size:var(--t-lg);font-weight:600;margin-bottom:.75rem;color:var(--text-primary);line-height:1.4;transition:color var(--transition)}.blog-card:hover .blog-title{color:var(--accent-blue)}.blog-excerpt{color:var(--text-secondary);margin-bottom:1.25rem;flex-grow:1;line-height:1.65;font-size:.9rem}.blog-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-subtle);flex-wrap:wrap;gap:.5rem}.blog-date{font-size:var(--t-xs);color:var(--text-muted);font-family:var(--font-mono)}.blog-tags{display:flex;gap:.4rem;flex-wrap:wrap}.blog-tag{background:#f0527a1a;color:var(--accent-pink);border:1px solid var(--border-accent);padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:var(--t-xs);font-weight:500}.rambling-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color var(--transition),box-shadow var(--transition);position:relative;box-shadow:var(--shadow-sm)}.rambling-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-md)}.rambling-title{font-family:var(--font-primary);font-size:var(--t-lg);font-weight:600;margin-bottom:.75rem;color:var(--text-primary);padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle);display:block}.rambling-content{color:var(--text-secondary);line-height:1.75;margin-bottom:1.25rem;font-style:italic;padding-left:1rem;border-left:2px solid var(--accent-pink);font-size:.95rem}.rambling-meta{display:flex;justify-content:space-between;align-items:center;font-size:var(--t-xs);color:var(--text-muted);border-top:1px solid var(--border-subtle);padding-top:.75rem;margin-top:.5rem}.rambling-mood{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .65rem;border-radius:var(--radius-sm);font-size:var(--t-xs);font-weight:500;background:#2e5ef51a;color:var(--accent-blue);border:1px solid rgba(46,94,245,.25)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-top:2rem}.skill-category{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;text-align:center}.skill-category h4{font-family:var(--font-primary);font-size:var(--t-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:1rem}.skill-list{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}.skill-item{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);padding:.3rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;transition:all var(--transition);cursor:default}.skill-item:hover{background:var(--accent-blue);border-color:var(--accent-blue);color:var(--text-inverse)}.contact-form{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-md)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.4rem;color:var(--text-secondary);font-size:var(--t-xs);font-weight:500;text-transform:uppercase;letter-spacing:.06em}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-primary);font-size:.9rem;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #2e5ef526}.form-group textarea{resize:vertical;min-height:120px}.blog-body h2{font-family:var(--font-display);font-size:var(--t-xl);font-weight:400;color:var(--text-primary);margin-top:2.5rem;margin-bottom:1rem}@media (max-width: 768px){main{padding-top:64px}.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1rem}.hero-cta{flex-direction:column;align-items:center}.experience-header{flex-direction:column;align-items:flex-start}.section-title{font-size:1.75rem}.contact-form{padding:1.5rem}}@media (max-width: 480px){main{padding-top:60px}.hero-title{font-size:2rem}.hero-tagline{font-size:.85rem}.experience-card,.blog-card,.rambling-card{padding:1.25rem}}
