*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body,h1,h2,h3,p{margin:0}img{display:block;max-width:100%}button,input,textarea{font:inherit}body{min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.7;text-rendering:optimizeLegibility;transition:background .24s ease-in-out,color .24s ease-in-out}body:before{content:"";position:fixed;inset:0;z-index:-1;background:radial-gradient(circle at top right,rgba(37,99,235,.08),transparent 28rem),radial-gradient(circle at bottom left,rgba(124,58,237,.07),transparent 30rem);pointer-events:none}a{color:var(--color-accent);text-decoration:none;font-weight:700;transition:color .16s ease-in-out,opacity .16s ease-in-out}a:hover{color:var(--color-accent-hover)}h1,h2,h3{color:var(--color-heading);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.15;letter-spacing:-.035em}p{color:var(--color-text)}.container{width:min(100% - 2rem,1180px);margin-inline:auto}.section{padding-block:clamp(3rem,6vw,5.5rem)}.section-title{max-width:820px;margin-bottom:1rem;font-size:clamp(2rem,4.2vw,3.35rem);font-weight:850;line-height:1.08}.section-subtitle{max-width:760px;color:var(--color-muted);font-size:clamp(1rem,2vw,1.125rem)}.eyebrow{font-family:JetBrains Mono,SFMono-Regular,Consolas,monospace;margin-bottom:.85rem;color:var(--color-accent);font-size:.78rem;font-weight:850;letter-spacing:.16em;text-transform:uppercase}.hero-section{padding-top:clamp(3.5rem,7vw,6rem)}.hero-title{max-width:780px;font-size:clamp(2.25rem,4.4vw,3.5rem);line-height:1.08}.hero-role{margin-top:-.25rem;color:var(--color-accent);font-size:clamp(1.25rem,2vw,1.75rem);font-weight:850}.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:2rem}::selection{background:var(--color-accent-soft);color:var(--color-heading)}@media(max-width:640px){.container{width:min(100% - 1.25rem,1180px)}.section{padding-block:clamp(3rem,6vw,5.5rem)}.hero-actions{flex-direction:column;align-items:stretch}}:root,[data-theme=light]{--color-bg: #f4f7fb;--color-bg-soft: #eef3f8;--color-surface: #ffffff;--color-surface-elevated: #fdfefe;--color-heading: #172033;--color-text: #475569;--color-muted: #64748b;--color-accent: #2563eb;--color-accent-hover: #1d4ed8;--color-accent-soft: #dbeafe;--color-border: #d6e0ec;--shadow-card: 0 12px 30px rgba(15, 23, 42, .07);--shadow-card-hover: 0 18px 44px rgba(15, 23, 42, .12)}[data-theme=light] .about-card,[data-theme=light] .skill-card,[data-theme=light] .project-card,[data-theme=light] .contact-card,[data-theme=light] .hero-visual__card{background:linear-gradient(145deg,#fffffff0,#f8fbfff5)}[data-theme=dark]{--color-bg: #0b1120;--color-bg-soft: #111827;--color-surface: #111827;--color-surface-elevated: #172033;--color-text: #e5e7eb;--color-heading: #f8fafc;--color-muted: #a8b3c7;--color-border: #2b3548;--color-accent: #60a5fa;--color-accent-hover: #93c5fd;--color-accent-soft: rgba(96, 165, 250, .16);--color-success: #4ade80;--color-danger: #f87171;--shadow-card: 0 18px 42px rgba(0, 0, 0, .35);--shadow-card-hover: 0 22px 54px rgba(0, 0, 0, .45);--navbar-bg: rgba(15, 23, 42, .88);--input-bg: #0f172a}[data-theme=glass]{--color-bg: radial-gradient(circle at top left, #312e81 0%, #0f172a 42%, #020617 100%);--color-bg-soft: rgba(15, 23, 42, .72);--color-surface: rgba(255, 255, 255, .1);--color-surface-elevated: rgba(255, 255, 255, .14);--color-text: #eef2ff;--color-heading: #ffffff;--color-muted: #c7d2fe;--color-border: rgba(255, 255, 255, .2);--color-accent: #c4b5fd;--color-accent-hover: #ddd6fe;--color-accent-soft: rgba(196, 181, 253, .18);--color-success: #86efac;--color-danger: #fca5a5;--shadow-card: 0 18px 45px rgba(0, 0, 0, .38);--shadow-card-hover: 0 24px 60px rgba(0, 0, 0, .48);--navbar-bg: rgba(15, 23, 42, .62);--input-bg: rgba(15, 23, 42, .42)}.button,.theme-switcher__button,.like-button__control,.contact-form button[type=submit]{display:inline-flex;align-items:center;justify-content:center;min-height:2.75rem;border:1px solid var(--color-border);border-radius:999px;padding:.7rem 1.15rem;background:var(--color-surface-elevated);color:var(--color-heading);cursor:pointer;font:inherit;font-size:.92rem;font-weight:800;line-height:1;text-decoration:none;box-shadow:0 3px 10px #0f172a0f;transition:background .16s ease-in-out,color .16s ease-in-out,border-color .16s ease-in-out,box-shadow .16s ease-in-out,transform .16s ease-in-out}.button:hover,.theme-switcher__button:hover,.like-button__control:hover,.contact-form button[type=submit]:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px);box-shadow:0 8px 20px #0f172a1f}.button--primary,.contact-form button[type=submit]{border-color:color-mix(in srgb,var(--color-accent) 82%,#000000);background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent) 88%,#000000),color-mix(in srgb,var(--color-accent-hover) 84%,#000000));color:#fff;box-shadow:0 10px 24px color-mix(in srgb,var(--color-accent) 22%,transparent)}.button--primary:hover,.contact-form button[type=submit]:hover{border-color:color-mix(in srgb,var(--color-accent-hover) 78%,#000000);background:linear-gradient(135deg,color-mix(in srgb,var(--color-accent-hover) 88%,#000000),color-mix(in srgb,var(--color-accent) 82%,#000000));color:#fff;transform:translateY(-1px);box-shadow:0 12px 28px color-mix(in srgb,var(--color-accent) 26%,transparent)}.theme-switcher{display:inline-flex;align-items:center;gap:.4rem;flex-wrap:wrap;border:1px solid var(--color-border);border-radius:999px;padding:.25rem;background:var(--color-surface)}.theme-switcher__button{min-height:2.25rem;border-color:transparent;padding:.5rem .85rem;box-shadow:none}html[data-theme=dark] .theme-switcher__button[data-theme-value=dark],html[data-theme=light] .theme-switcher__button[data-theme-value=light],html[data-theme=glass] .theme-switcher__button[data-theme-value=glass],.theme-switcher__button[aria-pressed=true]{border-color:color-mix(in srgb,var(--color-accent) 55%,var(--color-border));background:color-mix(in srgb,var(--color-accent-soft) 55%,transparent);color:var(--color-accent);box-shadow:none}html[data-theme=dark] .theme-switcher__button[data-theme-value=dark]:hover,html[data-theme=light] .theme-switcher__button[data-theme-value=light]:hover,html[data-theme=glass] .theme-switcher__button[data-theme-value=glass]:hover,.theme-switcher__button[aria-pressed=true]:hover{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent)}.like-button{display:inline-flex;align-items:center;gap:.75rem;flex-wrap:wrap}.like-button__control:disabled{cursor:not-allowed;opacity:.72;transform:none}.like-button__count{color:var(--color-muted);font-size:.92rem;font-weight:800}.site-header{position:sticky;top:0;z-index:20;border-bottom:1px solid var(--color-border);background:var(--navbar-bg);backdrop-filter:blur(18px)}.navbar{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;min-height:4.75rem}.navbar__brand{color:var(--color-heading);font-size:1rem;font-weight:900;letter-spacing:-.035em}.navbar__nav{display:flex;align-items:center;gap:.35rem}.navbar__link{border-radius:999px;padding:.55rem .85rem;color:var(--color-muted);font-size:.92rem;font-weight:800}.navbar__link:hover{background:var(--color-accent-soft);color:var(--color-accent)}@media(max-width:820px){.navbar{flex-wrap:wrap;justify-content:center;padding-block:.9rem}.navbar__brand{width:100%;text-align:center}.navbar__nav{order:3;width:100%;justify-content:center;flex-wrap:wrap}}.project-grid{display:grid;grid-template-columns:1fr;gap:1.35rem;margin-top:2.25rem}.project-card{display:flex;flex-direction:column;gap:1.1rem;min-height:100%;border:1px solid var(--color-border);border-radius:1.25rem;padding:1.45rem;background:var(--color-surface);box-shadow:var(--shadow-card);transition:transform .16s ease-in-out,border-color .16s ease-in-out,box-shadow .16s ease-in-out,background .24s ease-in-out}[data-theme=glass] .project-card,[data-theme=glass] .contact-form,[data-theme=glass] .contact-card,[data-theme=glass] .about-card,[data-theme=glass] .project-detail__section{backdrop-filter:blur(18px)}.project-card:hover{transform:translateY(-4px);border-color:var(--color-accent);box-shadow:var(--shadow-card-hover)}.project-card__header{display:flex;justify-content:space-between;gap:.75rem;align-items:center}.project-card__category,.project-card__status,.project-card__tech-item{display:inline-flex;align-items:center;width:fit-content;border:1px solid transparent;border-radius:999px;padding:.38rem .72rem;background:var(--color-accent-soft);color:var(--color-heading);font-size:.78rem;font-weight:850;line-height:1}.project-card__title{color:var(--color-heading);font-size:1.25rem;font-weight:850;line-height:1.25}.project-card__summary{color:var(--color-muted);font-size:.96rem}.project-card__tech-list{display:flex;flex-wrap:wrap;gap:.5rem;padding:0;margin:0;list-style:none}.project-card__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:auto;padding-top:.25rem}@media(min-width:760px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1120px){.project-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.site-footer{border-top:1px solid var(--color-border);padding-block:2rem;color:var(--color-muted);background:transparent}.site-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-footer p{color:var(--color-muted);font-size:.92rem}.site-footer__links{display:flex;gap:1rem;flex-wrap:wrap}.site-footer__links a{position:relative;display:inline-flex;align-items:center;color:var(--color-accent);font-size:.92rem;font-weight:850;letter-spacing:.01em;text-decoration:none;transition:color .18s ease-in-out,transform .18s ease-in-out,text-shadow .18s ease-in-out}.site-footer__links a:after{content:"";position:absolute;left:0;bottom:-.28rem;width:100%;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));transform:scaleX(0);transform-origin:right;transition:transform .22s ease-in-out}.site-footer__links a:hover{color:var(--color-accent-hover);transform:translateY(-2px);text-shadow:0 0 18px color-mix(in srgb,var(--color-accent) 45%,transparent)}.site-footer__links a:hover:after{transform:scaleX(1);transform-origin:left}.site-footer__links a:focus-visible{outline:3px solid var(--color-accent-soft);outline-offset:.35rem;border-radius:.4rem}@media(max-width:720px){.site-footer__inner{flex-direction:column;text-align:center}}.project-detail{max-width:920px}.project-detail__back-link{display:inline-flex;margin-bottom:2rem;color:var(--color-muted);font-weight:850}.project-detail__back-link:hover{color:var(--color-accent)}.project-detail__header{margin-bottom:3rem}.project-detail__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}.project-detail__content{display:grid;gap:1.25rem}.project-detail__section{border:1px solid var(--color-border);border-radius:1.25rem;padding:1.5rem;background:var(--color-surface);box-shadow:var(--shadow-card)}.project-detail__section h2{margin-bottom:.75rem;color:var(--color-heading);font-size:1.25rem;font-weight:850}.project-detail__section p,.project-detail__section li{color:var(--color-muted)}.project-detail__section ul{margin:0;padding-left:1.25rem}.project-detail__tag-list{display:flex;flex-wrap:wrap;gap:.5rem;padding-left:0!important;list-style:none}.project-detail__tag-list li{border-radius:999px;padding:.4rem .72rem;background:var(--color-accent-soft);color:var(--color-heading);font-size:.85rem;font-weight:850}.contact-page__intro{margin-bottom:2.5rem}.contact-page__grid{display:grid;grid-template-columns:1fr;gap:1.5rem}.contact-form,.contact-card{border:1px solid var(--color-border);border-radius:1.25rem;padding:clamp(1.25rem,3vw,1.75rem);background:var(--color-surface);box-shadow:var(--shadow-card)}.contact-form{display:grid;gap:1.2rem}.form-field{display:grid;gap:.55rem}.form-field__label{color:var(--color-heading);font-size:.92rem;font-weight:850}.form-field__input{width:100%;border:1px solid var(--color-border);border-radius:.75rem;padding:.95rem 1rem;background:var(--input-bg);color:var(--color-text);outline:none;font:inherit;transition:border-color .16s ease-in-out,box-shadow .16s ease-in-out,background .24s ease-in-out}.form-field__input::placeholder{color:var(--color-muted);opacity:.78}.form-field__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 4px var(--color-accent-soft)}.form-field__textarea{resize:vertical;min-height:160px}.contact-form__status{min-height:1.5rem;color:var(--color-muted);font-weight:800}.contact-form__status[data-status=success]{color:var(--color-success)}.contact-form__status[data-status=error]{color:var(--color-danger)}.contact-form__status[data-status=info]{color:var(--color-muted)}.contact-card h2{margin-bottom:1rem;color:var(--color-heading);font-size:1.2rem;font-weight:850}.contact-card__section-title{margin-top:1.6rem}.contact-card p{margin-top:1rem;color:var(--color-muted)}.contact-card__links{display:grid;gap:.7rem;padding:0;margin:0;list-style:none}.contact-card__links a{color:var(--color-accent);font-weight:850}@media(min-width:920px){.contact-page__grid{grid-template-columns:minmax(0,1.25fr) minmax(300px,.75fr);align-items:start}}.about-content{display:grid;grid-template-columns:1fr;gap:1.25rem;margin-top:2.25rem}.about-card{border:1px solid var(--color-border);border-radius:1.25rem;padding:1.5rem;background:var(--color-surface);box-shadow:var(--shadow-card)}.about-card h2{margin-bottom:.75rem;color:var(--color-heading);font-size:1.2rem;font-weight:850}.about-card p{color:var(--color-muted)}@media(min-width:880px){.about-content{grid-template-columns:repeat(3,minmax(0,1fr))}}.skill-stack{margin-top:clamp(3.5rem,6vw,5rem)}.skill-stack__header{margin-bottom:2rem}.skill-stack__title{font-size:clamp(1.9rem,3vw,2.7rem)}.skill-stack__grid{display:grid;grid-template-columns:1fr;gap:1.25rem}.skill-card{border:1px solid var(--color-border);border-radius:1.25rem;padding:1.5rem;background:linear-gradient(145deg,var(--color-surface-elevated),var(--color-surface));box-shadow:var(--shadow-card);transition:transform .16s ease-in-out,border-color .16s ease-in-out,box-shadow .16s ease-in-out}.skill-card:hover{transform:translateY(-3px);border-color:var(--color-accent);box-shadow:var(--shadow-card-hover)}.skill-card h3{margin-bottom:.7rem;color:var(--color-heading);font-size:1.1rem;font-weight:850}.skill-card p{margin-bottom:1.1rem;color:var(--color-muted);font-size:.95rem}.skill-card__chips{display:flex;flex-wrap:wrap;gap:.55rem;padding:0;margin:0;list-style:none}.skill-card__chips li{border:1px solid var(--color-border);border-radius:999px;padding:.48rem .78rem;background:var(--color-accent-soft);color:var(--color-heading);font-size:.8rem;font-weight:850;line-height:1}[data-theme=glass] .skill-card{backdrop-filter:blur(18px)}@media(min-width:760px){.skill-stack__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1120px){.skill-stack__grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.hero-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:3rem;align-items:center}.hero-content{max-width:760px}.hero-title{max-width:760px;font-size:clamp(2.75rem,5vw,4.25rem);line-height:1.05}.hero-role{margin-bottom:1rem;color:var(--color-accent);font-size:clamp(1.35rem,2vw,1.8rem);font-weight:850;letter-spacing:-.02em}.hero-visual{display:none}.hero-visual__card{position:relative;width:min(100%,380px);margin-left:auto;border:1px solid var(--color-border);border-radius:2rem;padding:1.75rem;background:linear-gradient(145deg,var(--color-surface-elevated),var(--color-surface));box-shadow:var(--shadow-card-hover);overflow:hidden;transition:transform .24s ease-in-out,border-color .24s ease-in-out,box-shadow .24s ease-in-out}.hero-visual__card:before{content:"";position:absolute;inset:-35%;background:radial-gradient(circle at 50% 20%,color-mix(in srgb,var(--color-accent) 24%,transparent),transparent 34%);opacity:.85;pointer-events:none}.hero-visual__card:hover{transform:translateY(-4px);border-color:var(--color-accent)}.hero-visual__avatar-ring,.hero-visual__content,.hero-visual__divider,.hero-visual__skills{position:relative;z-index:1}.hero-visual__avatar-ring{display:grid;place-items:center;width:150px;height:150px;margin-inline:auto;margin-bottom:1.5rem;border-radius:999px;background:conic-gradient(from 180deg,var(--color-accent),var(--color-accent-hover),var(--color-accent));padding:3px;box-shadow:0 20px 55px color-mix(in srgb,var(--color-accent) 22%,transparent)}.hero-visual__avatar{width:100%;height:100%;border-radius:999px;overflow:hidden;background:var(--color-surface)}.hero-visual__avatar img{width:100%;height:100%;display:block;object-fit:cover;object-position:center 28%}.hero-visual__content{text-align:center}.hero-visual__label{margin-bottom:.45rem;color:var(--color-accent);font-size:.78rem;font-weight:850;letter-spacing:.16em;text-transform:uppercase}.hero-visual__content h2{margin-bottom:.35rem;color:var(--color-heading);font-size:1.45rem;font-weight:850}.hero-visual__content p{color:var(--color-muted)}.hero-visual__divider{width:100%;height:1px;margin-block:1.35rem;background:var(--color-border)}.hero-visual__skills{display:flex;flex-wrap:wrap;justify-content:center;gap:.55rem}.hero-visual__skills span{border:1px solid var(--color-border);border-radius:999px;padding:.48rem .78rem;background:var(--color-accent-soft);color:var(--color-heading);font-size:.8rem;font-weight:850;line-height:1}[data-theme=glass] .hero-visual__card{backdrop-filter:blur(18px)}@media(min-width:980px){.hero-grid{grid-template-columns:minmax(0,.95fr) minmax(320px,.75fr)}.hero-visual{display:block}}@media(max-width:640px){.hero-title{font-size:clamp(2.4rem,12vw,3.1rem)}}.project-walkthrough{max-width:1120px}.project-walkthrough__header{max-width:760px;margin-bottom:clamp(2.5rem,5vw,4rem)}.walkthrough-featured{margin-bottom:clamp(3.5rem,7vw,5.5rem)}.walkthrough-section-heading{margin-bottom:1.25rem}.walkthrough-section-heading h2{color:var(--color-heading);font-size:clamp(1.55rem,2.5vw,2.2rem);line-height:1.15}.walkthrough-card{overflow:hidden;border:1px solid var(--color-border);border-radius:1.25rem;background:linear-gradient(145deg,var(--color-surface-elevated),var(--color-surface));box-shadow:var(--shadow-card)}.walkthrough-card--featured{display:grid;gap:0}.walkthrough-card__body{padding:1.25rem}.walkthrough-card__body h3{margin-bottom:.45rem;color:var(--color-heading);font-size:1.05rem;font-weight:850}.walkthrough-card__body p{color:var(--color-muted);font-size:.95rem}.walkthrough-card__media-shell{width:100%;aspect-ratio:16/9;overflow:hidden;border-top:1px solid var(--color-border);background:#000}.walkthrough-card__media-shell img,.walkthrough-card__media-shell video,.walkthrough-card__media-shell iframe{width:100%;height:100%;display:block;border:0}.walkthrough-card__media-shell img{object-fit:contain;object-position:center}.walkthrough-card__media-shell video{object-fit:contain}.walkthrough-gallery__grid{display:grid;grid-template-columns:1fr;gap:1.25rem}[data-theme=glass] .walkthrough-card{backdrop-filter:blur(18px)}@media(min-width:820px){.walkthrough-gallery__grid{grid-template-columns:repeat(2,minmax(0,1fr))}.walkthrough-card--featured .walkthrough-card__body{padding:1.5rem}}
