:root{--color-bg: #0f0f0f;--color-surface-1: #1a1a1a;--color-surface-2: #242424;--color-surface-3: #2a2a2a;--color-border: #333;--color-border-light: #3a3a3a;--color-text-primary: #f0f0f0;--color-text-secondary: #b0b0b0;--color-text-muted: #888;--color-accent: #4a9eff;--color-accent-hover: #6bb4ff;--color-accent-dim: rgba(74, 158, 255, .1);--color-error: #e74c3c;--color-success: #4caf50;--font-heading: "DM Serif Display", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .825rem + .25vw, .95rem);--text-base: clamp(.95rem, .9rem + .25vw, 1rem);--text-lg: clamp(1.05rem, 1rem + .25vw, 1.125rem);--text-xl: clamp(1.2rem, 1.1rem + .5vw, 1.35rem);--text-2xl: clamp(1.5rem, 1.2rem + 1vw, 2rem);--text-3xl: clamp(2rem, 1.5rem + 2vw, 3rem);--text-4xl: clamp(2.5rem, 2rem + 2.5vw, 4rem);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .6);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text-primary);line-height:1.6;min-width:320px}#root{width:100%;min-height:100vh}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-surface-1)}::-webkit-scrollbar-thumb{background:var(--color-surface-3);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4a4a4a}*{scrollbar-width:thin;scrollbar-color:var(--color-surface-3) var(--color-surface-1)}.app{width:100%;min-height:100vh}.hero{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at center,var(--color-accent-dim) 0%,transparent 60%),var(--color-bg);padding:var(--space-xl);position:relative}.hero-content{text-align:center;max-width:700px;animation:fadeIn .8s ease both}.hero-name{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:400;color:#fff;line-height:1.1;margin-bottom:var(--space-md);letter-spacing:-.01em}.hero-title{font-size:var(--text-2xl);color:var(--color-accent);font-weight:500;margin-bottom:var(--space-lg);line-height:1.2}.hero-subtitle{font-size:var(--text-base);color:var(--color-text-muted);line-height:1.7;max-width:600px;margin:0 auto var(--space-xl)}.hero-links{display:flex;align-items:center;justify-content:center;gap:var(--space-md);margin-bottom:var(--space-2xl);flex-wrap:wrap}.hero-link{color:var(--color-text-secondary);text-decoration:none;font-size:var(--text-sm);transition:color var(--transition-fast)}.hero-link:hover{color:var(--color-accent)}.hero-link-text{color:var(--color-text-secondary);font-size:var(--text-sm)}.hero-divider{color:var(--color-border);font-size:var(--text-sm);-webkit-user-select:none;user-select:none}.hero-cta{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.75rem 1.75rem;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.hero-cta:hover{background:var(--color-accent-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.hero-cta:active{transform:translateY(0)}.resume-main{background:var(--color-surface-1);padding:clamp(2rem,4vw,4rem) clamp(1rem,3vw,2rem)}.resume-content{max-width:800px;margin:0 auto;line-height:1.6;-webkit-user-select:text;user-select:text}.resume-content-section{margin-bottom:var(--space-2xl)}.resume-content-section h3{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:400;color:var(--color-accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.resume-content-section p{color:var(--color-text-primary);margin-bottom:var(--space-md);font-size:var(--text-base);line-height:1.7}.skills-grid{display:grid;gap:var(--space-sm);color:var(--color-text-primary);font-size:var(--text-sm);line-height:1.6}.skills-grid strong{color:#fff;font-weight:600}.job{margin-bottom:var(--space-xl)}.job-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--space-xs);flex-wrap:wrap;gap:var(--space-sm)}.job-header strong{font-size:var(--text-lg);color:#fff;font-weight:600}.job-header span{color:var(--color-accent);font-weight:500;font-size:var(--text-sm)}.job-meta{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-md);font-style:italic}.job ul{list-style:none;padding-left:0}.job ul li{position:relative;padding-left:1.25rem;margin-bottom:var(--space-sm);color:var(--color-text-primary);font-size:var(--text-sm);line-height:1.6}.job ul li:before{content:"•";position:absolute;left:0;color:var(--color-accent);font-weight:700}.project{margin-bottom:var(--space-lg);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);transition:border-color var(--transition-base)}.project:hover{border-color:var(--color-border-light)}.project strong{display:block;color:#fff;font-weight:600;margin-bottom:var(--space-sm);font-size:var(--text-base)}.project p{color:var(--color-text-primary);font-size:var(--text-sm);margin-bottom:0;line-height:1.6}.project a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}.project a:hover{color:var(--color-accent-hover);text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}[data-animate]{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}[data-animate].visible{opacity:1;transform:translateY(0)}[data-animate]:nth-child(2){transition-delay:.1s}[data-animate]:nth-child(3){transition-delay:.15s}[data-animate]:nth-child(4){transition-delay:.2s}.chat-widget{position:fixed;bottom:var(--space-lg);right:var(--space-lg);z-index:1000}.chat-fab{width:56px;height:56px;border-radius:var(--radius-full);background:var(--color-accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:all var(--transition-base);animation:fabPulse 3s ease-in-out infinite}.chat-fab:hover{background:var(--color-accent-hover);transform:scale(1.08);box-shadow:var(--shadow-xl)}.chat-fab:active{transform:scale(.95)}@keyframes fabPulse{0%,to{box-shadow:var(--shadow-lg),0 0 #4a9eff4d}50%{box-shadow:var(--shadow-lg),0 0 0 12px #4a9eff00}}.chat-panel{width:420px;max-height:600px;display:flex;flex-direction:column;background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:slideUp .3s ease both}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--color-accent-dim);border-bottom:1px solid var(--color-border);flex-shrink:0}.chat-panel-header h3{font-family:var(--font-body);font-size:var(--text-base);font-weight:600;color:var(--color-accent);margin:0}.chat-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.chat-close-button:hover{background:var(--color-surface-3);color:var(--color-text-primary)}.chat-container{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-surface-2)}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:var(--space-xl)}.auth-container h2{font-family:var(--font-body);font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-sm)}.auth-container p{color:var(--color-text-muted);font-size:var(--text-sm)}.reconnect-prompt{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000eb;padding:var(--space-xl);border-radius:var(--radius-lg);text-align:center;z-index:1000;min-width:280px;border:1px solid var(--color-error)}.reconnect-prompt h3{margin-bottom:var(--space-md);color:var(--color-error);font-family:var(--font-body);font-size:var(--text-lg);font-weight:600}.reconnect-prompt p{margin-bottom:var(--space-lg);color:var(--color-text-secondary);font-size:var(--text-sm)}.reconnect-button{padding:.625rem 1.25rem;font-size:var(--text-sm);font-family:var(--font-body);background:var(--color-success);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;transition:background var(--transition-fast)}.reconnect-button:hover{background:#45a049}.messages{flex:1;overflow-y:auto;padding:var(--space-lg);padding-bottom:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);min-height:0}.welcome-message{text-align:center;margin-top:var(--space-xl);padding:0 var(--space-md)}.welcome-message h2{font-family:var(--font-heading);font-size:var(--text-xl);margin-bottom:var(--space-sm);color:#fff}.welcome-message p{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.suggested-prompts{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center}.prompt-chip{padding:.375rem .875rem;background:var(--color-accent-dim);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-accent);font-family:var(--font-body);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.prompt-chip:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.message{display:flex;margin-bottom:0}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{max-width:80%;padding:.625rem .875rem;border-radius:var(--radius-lg);word-wrap:break-word;line-height:1.5;font-size:var(--text-sm)}.message.user .message-content{background:var(--color-accent);color:#fff;border-bottom-right-radius:var(--radius-sm)}.message.assistant .message-content{background:var(--color-surface-3);color:var(--color-text-primary);border:1px solid var(--color-border);border-bottom-left-radius:var(--radius-sm)}.typing{display:flex;gap:.3rem;align-items:center;padding:.625rem .875rem}.typing span{width:6px;height:6px;border-radius:var(--radius-full);background:var(--color-accent);animation:typing 1.4s infinite}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.input-form{display:flex;gap:var(--space-sm);padding:var(--space-md);background:var(--color-surface-1);border-top:1px solid var(--color-border);flex-shrink:0}.message-input{flex:1;padding:.5rem .75rem;background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--text-sm);outline:none;transition:border-color var(--transition-fast)}.message-input::placeholder{color:var(--color-text-muted)}.message-input:focus{border-color:var(--color-accent)}.message-input:disabled{opacity:.5;cursor:not-allowed}.volume-control{position:relative;display:flex;align-items:center;flex-shrink:0}.volume-button{padding:0;width:2.25rem;height:2.25rem;background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.volume-button:hover{background:var(--color-border)}.volume-slider-container{position:absolute;bottom:calc(100% + .5rem);left:50%;transform:translate(-50%);background:var(--color-surface-3);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-sm);display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-md);z-index:1001}.volume-slider{position:relative;display:flex;align-items:center;-webkit-user-select:none;user-select:none;touch-action:none;width:1.25rem;height:5rem}.volume-slider[data-orientation=vertical]{flex-direction:column;width:1.25rem}.volume-slider-track{position:relative;flex-grow:1;background:var(--color-border);border-radius:var(--radius-sm);width:.375rem;height:100%}.volume-slider-range{position:absolute;bottom:0;left:0;right:0;background:var(--color-accent);border-radius:var(--radius-sm)}.volume-slider-thumb{display:block;width:.875rem;height:.875rem;background:var(--color-accent);border-radius:var(--radius-full);cursor:grab;transition:all var(--transition-fast);box-shadow:0 2px 4px #0000004d}.volume-slider-thumb:hover{background:var(--color-accent-hover);transform:scale(1.15)}.volume-slider-thumb:active{cursor:grabbing}.volume-slider-thumb:focus{outline:none;box-shadow:0 0 0 3px #4a9eff4d}.volume-label{font-size:var(--text-xs);color:var(--color-accent);font-weight:600;min-width:2.5rem;text-align:center}.send-button{padding:.5rem 1rem;background:var(--color-accent);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.send-button:hover:not(:disabled){background:var(--color-accent-hover)}.send-button:disabled{opacity:.4;cursor:not-allowed}.stop-button{padding:.5rem 1rem;background:var(--color-error);border:none;border-radius:var(--radius-md);color:#fff;font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.stop-button:hover{background:#c0392b}@media(max-width:480px){.hero{padding:var(--space-md)}.hero-links{gap:var(--space-sm)}.resume-main{padding:var(--space-lg) var(--space-md)}.job-header,.job-meta{flex-direction:column;gap:var(--space-xs)}}@media(max-width:768px){.chat-widget.chat-widget--open{inset:0}.chat-panel{width:100%;max-height:100%;height:100%;border-radius:0;border:none}.message-input{font-size:16px}.message-content{max-width:85%}.suggested-prompts{flex-direction:column;align-items:center}}@media(min-width:769px)and (max-width:1024px){.chat-panel{width:380px;max-height:550px}}@media(min-width:1440px){.resume-content{max-width:860px}.hero-content{max-width:800px}}
