*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--bg-card: #1a1a1a;--bg-card-hover: #222222;--border: #2e2e2e;--border-hover: #6a5020;--text: #e8e8e8;--text-muted: #8a8a8a;--accent: #c9a84c;--accent-dim: #8a6d28;--accent-glow: rgba(201, 168, 76, .1);--rec: #cc1a2a;--nav-bg: #141414;--radius: 10px;--shadow: 0 4px 24px rgba(0, 0, 0, .5)}html,body{height:100%;background-color:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}ul{list-style:none}.portfolio{display:flex;flex-direction:column;min-height:100vh}.tab-content{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:2.5rem 1.5rem 4rem}.site-header{background:var(--nav-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;min-height:64px}.brand{display:flex;flex-direction:column;line-height:1.2}.brand-name{font-size:1.15rem;font-weight:700;color:var(--text);letter-spacing:.3px}.brand-title{font-size:.68rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.tab-nav{display:flex;gap:.2rem}.tab-btn{background:transparent;border:none;color:var(--text-muted);font-size:.86rem;font-weight:500;padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;transition:color .2s,background .2s;letter-spacing:.3px;font-family:inherit}.tab-btn:hover{color:var(--text);background:#ffffff0a}.tab-btn.active{color:var(--accent);background:var(--accent-glow);border-bottom:2px solid var(--accent);border-radius:var(--radius) var(--radius) 0 0}.site-footer{text-align:center;padding:1.5rem;color:var(--text-muted);font-size:.75rem;border-top:1px solid var(--border);letter-spacing:.5px}.section{animation:fadeIn .35s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.about-hero{display:flex;align-items:center;justify-content:space-between;gap:2rem;margin-bottom:3rem;padding:2.5rem 2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;position:relative;overflow:hidden}.about-hero:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,255,255,.012) 3px,rgba(255,255,255,.012) 4px);pointer-events:none}.about-hero:after{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:linear-gradient(to bottom,var(--accent),transparent);border-radius:12px 0 0 12px}.about-intro{flex:1;min-width:0}.about-eyebrow{font-size:.72rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem;font-weight:600}.about-intro h1{font-size:2.6rem;font-weight:800;color:var(--text);line-height:1.1;margin-bottom:.75rem;letter-spacing:-.5px}.tagline{font-size:.95rem;color:var(--text-muted);line-height:1.65;margin-bottom:1.25rem;max-width:380px}.hero-badges{display:flex;gap:.5rem;flex-wrap:wrap}.hero-badge{font-size:.72rem;font-weight:600;letter-spacing:.8px;padding:.3rem .8rem;border-radius:999px;border:1px solid var(--border-hover);color:var(--text-muted);text-transform:uppercase}.profile-photo-wrap{flex-shrink:0;width:230px;height:295px;border-radius:12px;overflow:hidden;border:1px solid var(--border);box-shadow:0 12px 40px #00000080;position:relative}.profile-photo-wrap:after{content:"";position:absolute;inset:0;border-radius:12px;box-shadow:inset 0 0 0 1px #c9a84c14;pointer-events:none}.profile-photo{width:100%;height:100%;object-fit:cover;object-position:center 75%;display:block;transition:transform .5s ease}.profile-photo-wrap:hover .profile-photo{transform:scale(1.03)}@keyframes tv-screen-pulse{0%,to{opacity:.82}40%{opacity:1}70%{opacity:.75}}@keyframes tv-scanline-sweep{0%{transform:translateY(0);opacity:.6}90%{transform:translateY(128px);opacity:.3}to{transform:translateY(128px);opacity:0}}.tv-screen-pulse{animation:tv-screen-pulse 2.8s ease-in-out infinite}.tv-scanline-sweep{animation:tv-scanline-sweep 3.2s linear infinite}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.about-card--full{grid-column:1 / -1}.about-bio{columns:2;column-gap:2.5rem}.about-bio p{break-inside:avoid}.about-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.4rem;transition:border-color .2s,background .2s}.about-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.about-card h2{font-size:.72rem;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}.about-card p{color:var(--text-muted);font-size:.9rem;line-height:1.7;margin-bottom:.7rem}.about-card p:last-child{margin-bottom:0}.skill-list li{display:flex;align-items:center;gap:.6rem;padding:.35rem 0;color:var(--text-muted);font-size:.88rem;border-bottom:1px solid var(--border)}.skill-list li:last-child{border-bottom:none}.skill-icon{color:var(--accent);font-size:.55rem}.contact-list li{padding:.4rem 0;color:var(--text-muted);font-size:.88rem;border-bottom:1px solid var(--border)}.contact-list li:last-child{border-bottom:none}.contact-list strong{color:var(--text);margin-right:.4rem}.resume-section-wrapper{max-width:760px;margin:0 auto}.resume-header{text-align:center;margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.resume-header h1{font-size:2.2rem;font-weight:800;margin-bottom:.4rem;letter-spacing:-.3px}.resume-subtitle{color:var(--accent);font-size:.88rem;letter-spacing:.5px;margin-bottom:.5rem}.resume-contact{color:var(--text-muted);font-size:.8rem;margin-bottom:1.25rem}.download-btn{background:transparent;border:1px solid var(--accent);color:var(--accent);padding:.5rem 1.4rem;border-radius:var(--radius);font-size:.82rem;font-family:inherit;cursor:pointer;transition:background .2s,color .2s}.download-btn:hover{background:var(--accent);color:#07080c}.resume-section{margin-bottom:2.5rem}.resume-section-title{font-size:.72rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.resume-items{display:flex;flex-direction:column;gap:1rem}.resume-item{padding:1.1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);border-left:3px solid var(--accent-dim);transition:border-color .2s}.resume-item:hover{border-color:var(--border-hover);border-left-color:var(--accent)}.resume-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.25rem;flex-wrap:wrap}.resume-item-role{display:block;font-weight:600;font-size:.98rem;color:var(--text)}.resume-item-org{display:block;font-size:.82rem;color:var(--accent);margin-top:.1rem}.resume-item-date{font-size:.78rem;color:var(--text-muted);white-space:nowrap;font-family:monospace}.resume-item-location{display:block;font-size:.78rem;color:var(--text-muted);margin-bottom:.6rem}.resume-item-desc{margin-top:.7rem;display:flex;flex-direction:column;gap:.3rem}.resume-item-desc li{font-size:.86rem;color:var(--text-muted);padding-left:1rem;position:relative;line-height:1.6}.resume-item-desc li:before{content:"–";position:absolute;left:0;color:var(--accent-dim)}.work-header{margin-bottom:2rem}.work-header h1{font-size:1.9rem;font-weight:800;margin-bottom:.4rem;letter-spacing:-.3px}.work-subtitle{color:var(--text-muted);font-size:.9rem}.category-filters{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:2rem}.filter-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);padding:.38rem 1rem;border-radius:999px;font-size:.8rem;font-family:inherit;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--border-hover);color:var(--text)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#07080c;font-weight:700}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.1rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .22s,border-color .22s,box-shadow .22s;cursor:default}.project-card:hover{transform:translateY(-5px);border-color:var(--border-hover);box-shadow:var(--shadow)}.project-thumbnail{height:126px;display:flex;align-items:flex-end;padding:.75rem 1rem;position:relative;overflow:hidden}.project-thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}.project-category-badge{font-size:.68rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;background:#0009;color:#fff;padding:.25rem .65rem;border-radius:999px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}a.project-card--linked{display:block;text-decoration:none;color:inherit;cursor:pointer}a.project-card--linked:hover{text-decoration:none}.project-watch-badge{position:absolute;top:.65rem;right:.75rem;font-size:.68rem;font-weight:700;letter-spacing:.5px;background:var(--accent);color:#07080c;padding:.22rem .6rem;border-radius:999px;transition:background .2s,transform .2s}a.project-card--linked:hover .project-watch-badge{background:#e0c060;transform:scale(1.06)}.project-info{padding:1.05rem 1.15rem 1.25rem}.project-meta{margin-bottom:.35rem}.project-year{font-size:.72rem;color:var(--accent);font-weight:700;letter-spacing:1px;font-family:monospace}.project-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.45rem}.project-description{font-size:.83rem;color:var(--text-muted);line-height:1.6;margin-bottom:.8rem}.project-tags{display:flex;gap:.4rem;flex-wrap:wrap}.tag{font-size:.7rem;background:var(--accent-glow);color:var(--accent);border:1px solid rgba(201,168,76,.2);padding:.18rem .6rem;border-radius:999px;letter-spacing:.3px}.no-results{text-align:center;color:var(--text-muted);padding:3rem 0}@media(max-width:720px){.about-hero{flex-direction:column;text-align:center;padding:1.75rem 1.25rem;gap:1.5rem}.about-intro h1{font-size:2rem}.tagline{max-width:100%}.hero-badges{justify-content:center}.profile-photo-wrap{order:-1;width:160px;height:205px}.about-grid{grid-template-columns:1fr}.about-bio{columns:1}}@media(max-width:640px){.header-inner{flex-direction:column;padding:.55rem 1rem;gap:.4rem;min-height:unset}.brand-title{display:none}.brand-name{font-size:1rem}.tab-nav{width:100%;justify-content:center}.tab-btn{font-size:.76rem;padding:.38rem .6rem;flex:1;text-align:center}.tab-content{padding:1.75rem 1rem 3rem}.resume-item-header{flex-direction:column;gap:.2rem}.resume-contact{line-height:1.8}.work-header h1{font-size:1.7rem}.resume-header h1{font-size:1.8rem}}@media(max-width:480px){.tab-content{padding:1.25rem .875rem 2.5rem}.profile-photo-wrap{width:130px;height:167px}.about-intro h1{font-size:1.75rem}.about-eyebrow{font-size:.66rem}.tagline{font-size:.88rem}.resume-header h1{font-size:1.6rem}.work-header h1{font-size:1.5rem}.projects-grid{grid-template-columns:1fr}.filter-btn{font-size:.74rem;padding:.3rem .75rem}.about-card{padding:1.1rem}}@media print{.site-header,.site-footer,.download-btn{display:none!important}.tab-content{padding:0}body{background:#fff;color:#000}}
