:root{--p-bg: #0a0b0d;--p-bg-2: #11141a;--p-bg-card: rgba(15, 23, 42, .6);--p-bg-card-solid: #131820;--p-fg: #e5e7eb;--p-fg-muted: #94a3b8;--p-fg-soft: #64748b;--p-accent: #22c55e;--p-accent-strong: #4ade80;--p-accent-glow: rgba(34, 197, 94, .22);--p-border: rgba(148, 163, 184, .18);--p-border-strong: rgba(148, 163, 184, .35);--p-radius: 14px;--p-radius-full: 999px}.portfolio{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:radial-gradient(ellipse 80% 50% at 50% -20%,#1e293b 0,#0a0b0d 45%,#000);color:var(--p-fg);min-height:100vh;line-height:1.6}.portfolio *{box-sizing:border-box}.portfolio img{max-width:100%;display:block}.portfolio a{color:inherit;text-decoration:none}.portfolio a:hover{color:var(--p-accent)}.container{max-width:1180px;margin:0 auto;padding:0 1.5rem}.hero{padding:5rem 0 4rem;position:relative}.hero-grid{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2.3fr);gap:3rem;align-items:center}.eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:var(--p-radius-full);border:1px solid var(--p-border-strong);background:#0f172a99;font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;color:var(--p-fg-muted);margin-bottom:1.25rem}.eyebrow-dot{width:8px;height:8px;border-radius:999px;background:var(--p-accent);box-shadow:0 0 10px #22c55eb3}.hero-title{font-size:clamp(2.4rem,4.5vw,3.4rem);line-height:1.05;letter-spacing:-.01em;margin:0 0 .6rem;font-weight:600}.hero-name{background:linear-gradient(120deg,#bbf7d0,#4ade80,#22c55e);background-clip:text;-webkit-background-clip:text;color:transparent}.hero-tagline{margin:0 0 1.4rem;font-size:1.05rem;color:var(--p-fg-muted)}.hero-summary{margin:0 0 1.6rem;font-size:1rem;color:#cbd5e1;max-width:38rem;line-height:1.65}.hero-tags{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.8rem}.pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .85rem;border-radius:var(--p-radius-full);border:1px solid var(--p-border);background:#0f172a80;font-size:.8rem;color:var(--p-fg-muted)}.pill-dot{width:6px;height:6px;border-radius:999px;background:var(--p-fg-soft)}.hero-actions{display:flex;flex-wrap:wrap;gap:.7rem}.btn{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem 1.15rem;border-radius:var(--p-radius-full);border:1px solid var(--p-border-strong);background:#0f172ab3;color:var(--p-fg);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease;font-family:inherit}.btn:hover{background:#22c55e1a;border-color:var(--p-accent);color:var(--p-fg)}.btn-primary{background:var(--p-accent);border-color:var(--p-accent);color:#051509}.btn-primary:hover{background:var(--p-accent-strong);border-color:var(--p-accent-strong);color:#051509}.hero-card{background:var(--p-bg-card);border:1px solid var(--p-border);border-radius:22px;padding:1.75rem 1.5rem;position:relative;box-shadow:0 22px 50px #00000073}.hero-avatar{display:flex;justify-content:center;margin-bottom:1.1rem;position:relative}.hero-avatar:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:999px;background:var(--p-accent);filter:blur(28px);opacity:.45;z-index:0}.hero-avatar img{position:relative;z-index:1;width:11rem;height:11rem;border-radius:999px;object-fit:cover;border:3px solid var(--p-accent)}.status-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:var(--p-radius-full);background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:var(--p-accent);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin:0 auto 1.2rem}.hero-card{text-align:left}.hero-card .status-pill{display:flex;width:fit-content;margin:0 auto 1.2rem}.status-dot{width:6px;height:6px;border-radius:999px;background:var(--p-accent);animation:pulse-soft 2s ease-in-out infinite}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.45}}.hero-card-body{display:flex;flex-direction:column;gap:0;margin-bottom:1.2rem}.hero-meta-row{display:grid;grid-template-columns:6.5rem 1fr;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--p-border);align-items:start}.hero-meta-row:last-child{border-bottom:none}.hero-meta-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--p-fg-soft);font-weight:600}.hero-meta-value{font-size:.88rem;color:var(--p-fg);line-height:1.45}.hero-contact{padding-top:1rem;border-top:1px solid var(--p-border);display:flex;flex-direction:column;gap:.4rem;font-size:.82rem;color:var(--p-fg-muted)}.hero-contact strong{color:var(--p-fg);font-weight:600}.hero-contact a{color:var(--p-accent)}.hero-contact a:hover{text-decoration:underline}.section{padding:4.5rem 0;position:relative}.section-alt{background:#0f172a59}.section-head{margin-bottom:2.5rem}.section-title{display:flex;align-items:center;gap:.85rem;font-size:clamp(1.5rem,2.4vw,2rem);font-weight:600;letter-spacing:-.01em;margin:0 0 .85rem;color:var(--p-fg)}.accent-bar{width:4px;height:1.5rem;background:var(--p-accent);border-radius:4px}.section-kicker{font-size:1rem;color:var(--p-fg-muted);max-width:56rem;margin:0;line-height:1.65}.timeline{position:relative;display:flex;flex-direction:column;gap:1.5rem}.timeline-item{position:relative;padding-left:2rem}.timeline-dot{position:absolute;left:.4rem;top:1.7rem;width:11px;height:11px;border-radius:999px;background:var(--p-bg-card-solid);border:2px solid var(--p-fg-soft);z-index:1}.timeline-item.is-current .timeline-dot{border-color:var(--p-accent);background:var(--p-accent);box-shadow:0 0 0 4px #22c55e2e}.timeline-item:before{content:"";position:absolute;left:.85rem;top:2.3rem;bottom:-1.5rem;width:1px;background:var(--p-border)}.timeline-item:last-child:before{display:none}.timeline-card{background:var(--p-bg-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:1.4rem 1.5rem}.timeline-item.is-current .timeline-card{border-color:#22c55e59;background:#22c55e0d}.exp-role{margin:0 0 .4rem;font-size:1.18rem;font-weight:600;color:var(--p-fg)}.exp-meta{display:flex;flex-wrap:wrap;gap:.25rem .85rem;font-size:.85rem;color:var(--p-fg-muted);margin-bottom:.9rem}.exp-meta span+span:before{content:"·";margin-right:.85rem;opacity:.6}.exp-bullets{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.45rem;color:#cbd5e1;font-size:.92rem;line-height:1.6}.exp-bullets li::marker{color:var(--p-accent)}.story-list{display:flex;flex-direction:column;gap:4rem}.story-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:2.5rem;align-items:start}.story-text h3{font-size:clamp(1.5rem,2.2vw,1.9rem);font-weight:600;margin:.4rem 0 .5rem;letter-spacing:-.01em;color:var(--p-fg)}.chapter-label{display:flex;align-items:baseline;gap:.8rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.18em}.chapter-num{color:var(--p-accent);font-weight:700;font-family:JetBrains Mono,SF Mono,monospace}.chapter-period{color:var(--p-fg-soft);font-family:JetBrains Mono,SF Mono,monospace;font-size:.7rem}.story-meta-line{font-size:.85rem;color:var(--p-fg-muted);margin-bottom:1.2rem}.story-text p{margin:0 0 .85rem;color:#cbd5e1;font-size:.96rem;line-height:1.7}.story-text p:last-child{margin-bottom:0}.story-media{position:sticky;top:2rem}.photo-slider{position:relative;background:var(--p-bg-card);border:1px solid var(--p-border);border-radius:16px;padding:.6rem .6rem 1.1rem}.slider-window{border-radius:12px;overflow:hidden;background:#020617;aspect-ratio:4 / 3}.slider-window img{width:100%;height:100%;object-fit:cover;cursor:zoom-in;display:block}.slider-nav{position:absolute;top:calc(50% - 1.7rem);width:2.4rem;height:2.4rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#0a0b0db3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--p-fg);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s}.slider-nav:hover{background:#22c55e99}.slider-nav[data-prev]{left:.85rem}.slider-nav[data-next]{right:.85rem}.slider-counter{position:absolute;top:1rem;right:1rem;padding:.2rem .6rem;border-radius:999px;background:#0a0b0db3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-family:JetBrains Mono,monospace;font-size:.7rem;color:var(--p-fg);letter-spacing:.06em}.slider-thumbs{display:grid;grid-template-columns:repeat(6,1fr);gap:.35rem;margin-top:.65rem}@media (min-width: 640px){.slider-thumbs{grid-template-columns:repeat(8,1fr)}}.slider-thumb{aspect-ratio:1;border:1px solid transparent;border-radius:6px;overflow:hidden;padding:0;cursor:pointer;background:transparent;opacity:.5;transition:opacity .15s,border-color .15s}.slider-thumb:hover{opacity:.85}.slider-thumb.is-active{opacity:1;border-color:var(--p-accent)}.slider-thumb img{width:100%;height:100%;object-fit:cover}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.lightbox img{max-width:100%;max-height:88vh;object-fit:contain;border-radius:8px}.lightbox-close,.lightbox-nav{position:absolute;width:2.8rem;height:2.8rem;border-radius:999px;border:none;background:#ffffff1a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--p-fg);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.lightbox-close{top:1rem;right:1rem}.lightbox-nav[data-prev]{left:1rem;top:50%;transform:translateY(-50%)}.lightbox-nav[data-next]{right:1rem;top:50%;transform:translateY(-50%)}.lightbox-close:hover,.lightbox-nav:hover{background:#fff3}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}.skill-card{background:var(--p-bg-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:1.3rem 1.4rem}.skill-cat{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--p-accent);font-weight:600;margin-bottom:.9rem}.skill-items{display:flex;flex-wrap:wrap;gap:.4rem}.awards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}.award-col{background:var(--p-bg-card);border:1px solid var(--p-border);border-radius:var(--p-radius);padding:1.3rem 1.4rem}.award-col-title{margin:0 0 1rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.16em;color:var(--p-fg-muted);font-weight:600}.award-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.award-list li{padding-bottom:.85rem;border-bottom:1px solid var(--p-border)}.award-list li:last-child{border-bottom:none;padding-bottom:0}.award-label{font-size:.95rem;color:var(--p-fg);font-weight:500;margin-bottom:.2rem}.award-meta{font-size:.78rem;color:var(--p-fg-soft)}.footer{border-top:1px solid var(--p-border);margin-top:2rem}.footer-inner{padding:1.6rem 1.5rem;font-size:.82rem;color:var(--p-fg-soft);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.personal-link{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:999px;border:1px solid var(--p-border);background:#0f172a8c;color:var(--p-fg-muted);font-size:.8rem;font-weight:500;transition:color .15s,border-color .15s,background .15s}.personal-link:hover{color:var(--p-accent);border-color:var(--p-accent);background:#22c55e14}@media (max-width: 900px){.hero-grid{grid-template-columns:1fr;gap:2rem}.hero-card{order:-1}.story-layout{grid-template-columns:1fr}.story-media{position:relative;top:auto}}@media (max-width: 540px){.hero{padding-top:3rem}.section{padding:3rem 0}.hero-meta-row{grid-template-columns:5rem 1fr}.timeline-item{padding-left:1.6rem}.timeline-item:before{left:.65rem}.timeline-dot{left:.2rem}}.login-shell{min-height:100vh;background:var(--bg, #020617);color:var(--text-main, #e5e7eb);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1.5rem;position:relative}.login-back{position:absolute;top:1.25rem;left:1.25rem;display:inline-flex;align-items:center;gap:.4rem;color:#94a3b8cc;font-size:.8rem;text-decoration:none;padding:.4rem .75rem;border-radius:999px;transition:color .15s,background .15s}.login-back:hover{color:#4ade80;background:#94a3b814;text-decoration:none}.login-card{width:100%;max-width:380px;background:#0f172ad9;border:1px solid rgba(148,163,184,.18);border-radius:22px;padding:2rem;box-shadow:0 24px 60px -20px #000000bf}.login-head{text-align:center;margin-bottom:1.6rem}.login-shield{width:56px;height:56px;margin:0 auto 1rem;border-radius:50%;background:linear-gradient(135deg,#22c55e,#4ade80);display:flex;align-items:center;justify-content:center;color:#020617}.login-title{font-size:1.4rem;font-weight:700;letter-spacing:-.015em;margin:0 0 .4rem;color:var(--text-main, #e5e7eb)}.login-sub{font-size:.88rem;line-height:1.5;color:#94a3b8f2;margin:0}.login-sub code{background:#22c55e1a;color:#4ade80;padding:.1rem .4rem;border-radius:6px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.82rem}.login-body{display:flex;flex-direction:column;gap:.6rem}.login-method{display:flex;align-items:center;gap:.7rem;padding:.85rem 1rem;border-radius:12px;background:#02061799;border:1px solid rgba(148,163,184,.2);color:var(--text-main, #e5e7eb);font-family:inherit;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.login-method:hover:not(:disabled){border-color:#4ade8080;background:#22c55e0f}.login-method:disabled{opacity:.55;cursor:not-allowed}.login-method svg:first-child{color:#4ade80;flex-shrink:0}.login-method-text{flex:1}.login-method-title{font-weight:600;font-size:.92rem}.login-method-sub{color:#94a3b8cc;font-size:.78rem;margin-top:.1rem}.login-hint{font-size:.78rem;color:#94a3b8b3;text-align:center;margin-top:.2rem}.login-digits{display:flex;gap:.4rem;justify-content:center;margin-bottom:.5rem}.login-digit{width:42px;height:52px;border-radius:10px;background:#02061799;border:1px solid rgba(148,163,184,.25);color:var(--text-main, #e5e7eb);font-size:1.4rem;font-weight:700;text-align:center;font-family:SF Mono,Menlo,Consolas,monospace;transition:border-color .15s,background .15s}.login-digit:focus{outline:none;border-color:#4ade80;background:#22c55e14}.login-digit:disabled{opacity:.6}.login-verifying{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.82rem;color:#94a3b8e6;padding:.3rem 0}.login-actions{display:flex;justify-content:space-between;gap:.5rem;margin-top:.4rem}.login-secondary{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .85rem;border-radius:999px;background:transparent;border:1px solid rgba(148,163,184,.2);color:#94a3b8f2;font-size:.78rem;font-family:inherit;cursor:pointer;transition:color .15s,border-color .15s,background .15s}.login-secondary:hover:not(:disabled){color:#4ade80;border-color:#4ade8066;background:#22c55e0f}.login-secondary:disabled{opacity:.5;cursor:not-allowed}.login-error{display:flex;align-items:center;gap:.4rem;margin-top:1rem;padding:.6rem .8rem;border-radius:10px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;font-size:.82rem}.spin{animation:login-spin 1s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}:root{--bg: #020617;--card-solid: #0b1322;--border: rgba(148, 163, 184, .18);--border-strong: rgba(148, 163, 184, .32);--fg: #e5e7eb;--muted: #9ca3af;--muted-soft: #6b7280;--secondary: rgba(15, 23, 42, .85);--primary: #22c55e;--primary-strong: #16a34a;--accent: #4ade80;--success: #22c55e;--warn: #facc15;--destructive: #ef4444;--on-primary: #020617;--glass-bg: rgba(15, 23, 42, .55);--kanban-col-bg: rgba(15, 23, 42, .45);--card-bg: rgba(15, 23, 42, .55);--header-bg: rgba(2, 6, 23, .94);--shadow-card: 0 1px 2px rgba(0,0,0,.4), 0 4px 14px -4px rgba(0,0,0,.45);--shadow-hover: 0 6px 18px rgba(0,0,0,.5);--shadow-strong: 0 24px 60px -20px rgba(0,0,0,.75);--primary-15: rgba(34, 197, 94, .15);--primary-30: rgba(34, 197, 94, .3);--primary-08: rgba(34, 197, 94, .08);--primary-06: rgba(34, 197, 94, .06)}.kanban-root,.kanban-root *{box-sizing:border-box}.kanban-root{background:var(--bg);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--fg)}.kanban-root ::selection{background:var(--primary-30);color:var(--fg)}.kanban-root button,.kanban-root input,.kanban-root textarea,.kanban-root select{font-family:inherit;color:var(--fg)}.kanban-root input:focus,.kanban-root textarea:focus,.kanban-root select:focus{outline:none}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes blink{0%,to{opacity:.4}50%{opacity:1}}@keyframes slideRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.fade-up{animation:fadeUp .28s ease-out both}.slide-right{animation:slideRight .18s ease-out both}.slide-left{animation:slideLeft .18s ease-out both}.typing-dot{display:inline-block;width:5px;height:5px;border-radius:999px;background:var(--primary);margin:0 1px;animation:blink 1.2s infinite}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}.glass{background:var(--glass-bg);border:1px solid var(--border);box-shadow:var(--shadow-card)}.react-card{transition:border-color .12s ease,transform .12s ease}.react-card:hover{transform:translateY(-1px);border-color:var(--primary-30)}.react-card.expanded{border-color:var(--primary-30)}.react-btn{transition:background .1s,color .1s,border-color .1s,filter .1s}.react-btn:hover:not(:disabled){filter:brightness(1.08)}.react-btn:active:not(:disabled){transform:scale(.96)}.react-icon-btn{transition:background .1s,color .1s}.react-icon-btn:hover:not(:disabled){background:var(--primary-15);color:var(--primary)}.react-icon-btn:active:not(:disabled){transform:scale(.92)}.react-tab{transition:background .1s,color .1s,border-color .1s}.react-input{transition:border-color .1s ease}.react-input:focus,.react-input:hover{border-color:var(--primary-30)!important}.react-row{transition:background .1s ease,border-color .1s ease}.react-row:hover{background:var(--primary-06)!important;border-color:var(--primary-30)!important}.react-day{transition:transform .1s ease,background .1s ease,border-color .1s ease}.react-day:hover{transform:scale(1.04);z-index:2}.react-day:active{transform:scale(.96)}.checkbox-wrap{transition:transform .1s ease}.checkbox-wrap:hover{transform:scale(1.1)}.checkbox-wrap:active{transform:scale(.94)}.tiny-label{font-family:Inter,system-ui,sans-serif;font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:600}.strikethrough{position:relative;display:inline-block;transition:opacity .3s ease-out .15s}.strikethrough.done{opacity:.45}.strikethrough:after{content:"";position:absolute;left:0;top:50%;width:0;height:2px;background:var(--primary);transition:width .35s ease}.strikethrough.done:after{width:100%}.kanban-card{cursor:grab}.kanban-card:active{cursor:grabbing}.kanban-card.dragging{opacity:.4}.column-dropping{background:var(--primary-08)!important;border-color:var(--primary-30)!important}.kanban-column{transition:background .1s,border-color .1s}.kanban-root ::-webkit-scrollbar{width:6px;height:6px}.kanban-root ::-webkit-scrollbar-track{background:transparent}.kanban-root ::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:3px}.kanban-root ::-webkit-scrollbar-thumb:hover{background:#94a3b866}.kanban-root select option{background:var(--card-solid);color:var(--fg)}.kanban-root input[type=date],.kanban-root input[type=time]{color-scheme:dark}
