:root{--bg: #0a0a0a;--text: #f5f5f5;--text-secondary: #d4d4d8;--muted: #a1a1aa;--border: #27272a;--black: #ffffff;--card-bg: #141414;--card-hover: #1a1a1a}:root.light-mode{--bg: #ffffff;--text: #111827;--text-secondary: #374151;--muted: #6B7280;--border: #e5e7eb;--black: #000000;--card-bg: #fafafa;--card-hover: #f5f5f5}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}.site-root{padding:2rem 1.25rem}.container{max-width:780px;margin:0 auto}.heading-xl{font-size:42px;font-weight:700;line-height:1.1;margin:0 0 .5rem;letter-spacing:-.02em}.heading-lg{font-size:24px;font-weight:700;margin:0 0 1.5rem;letter-spacing:-.01em}.heading-sm{font-size:18px;font-weight:700;margin:0}.lowercase{text-transform:lowercase}.site-header{padding:2rem 0 1.5rem;border-bottom:1px solid var(--border);margin-bottom:2.5rem}.greeting{margin:.5rem 0 .25rem;font-size:16px;color:var(--text-secondary)}.muted{color:var(--muted);font-size:14px;margin:0}.age-timer{display:inline-block;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;min-width:90px;text-align:left}.avatar{width:72px;height:72px;border-radius:50%;background:var(--black);display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;font-size:24px}.avatar-text{color:var(--bg);font-weight:700}.section{margin-bottom:3.5rem}.about-body p{line-height:1.65;margin:0 0 .875rem;color:var(--text-secondary);font-size:15px}.about-body p:last-child{margin-bottom:0}.about-body strong{color:var(--text);font-weight:600}.about-body a{color:var(--text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.about-body a:hover{text-decoration-thickness:2px}.cards-list{display:flex;flex-direction:column;gap:1.5rem}.card{display:flex;gap:.875rem;align-items:flex-start;text-decoration:none;color:inherit;padding:.75rem;border-radius:8px;transition:all .15s ease;border:1px solid transparent}.card:hover{background:var(--card-hover);border-color:var(--border)}.logo-box{width:44px;height:44px;min-width:44px;border-radius:6px;background:var(--black);color:var(--bg);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}.card-right{display:flex;flex-direction:column;gap:.25rem;flex:1}.card-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:.125rem}.card-meta{font-size:13px;color:var(--muted);font-weight:400}.card-role{font-size:14px;color:var(--text-secondary);margin-top:.125rem}.card-tech{font-size:12px;color:var(--muted);margin-top:.125rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.card-desc{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-top:.375rem}.project-card{flex-direction:column;align-items:flex-start;cursor:default}.project-card:hover{background:var(--card-hover);border-color:var(--border)}.project-card .card-right{width:100%}.repo-btn{display:inline-block;margin-top:.75rem;padding:.35rem .75rem;background:#ffffff1a;color:var(--text);text-decoration:none;border-radius:6px;font-size:12px;font-weight:500;transition:all .2s ease;border:1px solid rgba(255,255,255,.15)}.repo-btn:hover{background:#ffffff26;border-color:#ffffff40;transform:translateY(-1px)}.newsletter-form,.contact-form{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.input{border:1px solid var(--border);padding:.625rem .875rem;border-radius:6px;font-size:14px;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;transition:border-color .15s ease}.textarea{resize:vertical;min-height:120px;line-height:1.5}.input:focus{outline:none;border-color:var(--text);box-shadow:0 0 0 3px #1118270d}.input:disabled{opacity:.6;cursor:not-allowed}.btn{background:var(--black);color:var(--bg);border:none;padding:.625rem 1.25rem;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:transform .15s ease}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed}.form-result{font-size:13px;color:var(--text-secondary);margin-top:.75rem;font-style:italic}.theme-toggle{position:fixed;top:2rem;right:2rem;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--card-bg);color:var(--text);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:100}.theme-toggle:hover{transform:scale(1.1);border-color:var(--text)}.skills-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.skill-item{font-size:14px;color:var(--text-secondary);padding:.375rem 0}.projects-list{display:flex;flex-direction:column;gap:2rem;margin-top:1.5rem}.project-card-horizontal{display:flex;flex-direction:column;gap:1.5rem;overflow:hidden;border:1px solid var(--border);border-radius:12px;transition:all .25s ease;background:var(--card-bg);padding:1.25rem}.project-card-horizontal:hover{border-color:var(--text);box-shadow:0 8px 24px #0003}.project-image-container{width:100%;border-radius:8px;overflow:hidden;background:var(--border);border:1px solid var(--border);box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.project-card-horizontal:hover .project-image-container{border-color:#fff3;box-shadow:0 4px 16px #0003}.project-img{width:100%;height:100%;min-height:200px;display:block;object-fit:cover;object-position:center;transition:transform .3s ease}.project-card-horizontal:hover .project-img{transform:scale(1.03)}.project-content-horizontal{display:flex;flex-direction:column;gap:1rem;flex:1}.project-header-horizontal{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.project-title-horizontal{font-size:20px;font-weight:700;color:var(--text);margin:0;letter-spacing:-.01em}.project-date-horizontal{font-size:12px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.project-description-horizontal{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.project-tech-horizontal{font-size:12px;color:var(--muted);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;padding:.75rem;background:#ffffff08;border-radius:6px;border-left:2px solid rgba(255,255,255,.08);line-height:1.5}.project-actions-horizontal{display:flex;gap:.75rem;flex-wrap:wrap}.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:var(--black);color:var(--bg);text-decoration:none;border-radius:8px;font-size:13px;font-weight:600;transition:all .2s ease;border:1px solid var(--black);cursor:pointer;white-space:nowrap;letter-spacing:.3px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ffffff26}.btn-primary:active{transform:translateY(0)}.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;background:transparent;color:var(--text);text-decoration:none;border-radius:8px;font-size:13px;font-weight:600;transition:all .2s ease;border:1px solid var(--border);cursor:pointer;white-space:nowrap;letter-spacing:.3px}.btn-secondary:hover{border-color:var(--text);background:#ffffff0d;transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}.btn-primary svg,.btn-secondary svg{flex-shrink:0}.site-footer{padding:2.5rem 0 1rem;border-top:1px solid var(--border);margin-top:1rem}.footer-links{display:flex;flex-direction:column;gap:.5rem;font-size:14px}.footer-links a{color:var(--text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:text-decoration-thickness .15s ease}.footer-links a:hover{text-decoration-thickness:2px}@media(min-width:640px){.skills-list{grid-template-columns:repeat(3,1fr)}.newsletter-form{flex-direction:row;align-items:center}.input{flex:1}.project-card-horizontal{flex-direction:row;gap:2rem}.project-image-container{width:300px;min-width:300px;height:200px}.project-img{height:200px}}@media(min-width:768px){.site-root{padding:3rem 2rem}.site-header{padding:2.5rem 0 2rem}.heading-xl{font-size:48px}.card{padding:1rem}}
