.header{background-color:#0f172af2;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}@supports (backdrop-filter: blur(1px)){.header{background-color:#0f172acc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}.header-container{max-width:var(--container-max);margin:0 auto;padding:.5rem var(--page-padding);display:flex;justify-content:center;align-items:center}.nav-list{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2rem;list-style:none;margin:0;padding:0}.nav-link{color:var(--muted);text-decoration:none;font-weight:500;font-size:.9375rem;padding:.3rem .45rem;position:relative;transition:color var(--transition-fast);border-radius:2px}.nav-link:after{content:"";position:absolute;bottom:0;left:.5rem;width:0;height:2px;background-color:var(--color-primary);border-radius:1px;transition:width var(--transition-base)}.nav-link:hover:after,.nav-link.active:after{width:calc(100% - 1rem)}.nav-link:hover,.nav-link.active{color:var(--color-white)}.nav-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}@media (max-width: 768px){.header-container{padding:.6rem var(--page-padding)}.nav-list{gap:1.25rem}.nav-link{font-size:.875rem}}.footer{background-color:var(--surface);color:var(--text);padding:1.25rem var(--page-padding);margin-top:auto;border-top:1px solid var(--border)}.footer-container{max-width:var(--container-max);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:.5rem}.social-links{display:flex;gap:1.25rem}.social-link{color:var(--muted);text-decoration:none;display:flex;align-items:center;padding:.25rem;border-radius:4px;transition:color var(--transition-fast),transform var(--transition-fast)}.social-link:hover{color:var(--color-primary);transform:scale(1.1)}.social-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.social-link svg{width:20px;height:20px;fill:currentColor}.copyright{color:var(--muted);font-size:.8125rem;margin:0}.continuity-note{color:var(--muted);font-size:.75rem;margin:0;opacity:.7;font-style:italic}.project-card{background-color:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-md);transition:transform var(--transition-base),box-shadow var(--transition-base);display:flex;flex-direction:column;position:relative;height:100%}.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.project-card:hover .project-image img{transform:scale(calc(var(--card-zoom, 1) * 1.03))}.project-image-link{display:block;cursor:pointer;border-radius:var(--radius-lg)}.project-image-link:hover .project-image img,.project-image-link:hover .image-placeholder{opacity:.85}.project-image-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.project-image{width:100%;height:140px;overflow:hidden;background-color:var(--surface-2);position:relative}.project-image img{width:100%;height:100%;object-fit:cover;transform:scale(var(--card-zoom, 1));transition:opacity var(--transition-fast),transform var(--transition-base)}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);transition:opacity var(--transition-fast)}.image-placeholder span{font-size:4rem;font-weight:700;color:var(--color-white);opacity:.9}.project-content{padding:.85rem .75rem;display:flex;flex-direction:column;flex:1;gap:.75rem}.project-card-bottom{margin-top:auto;display:flex;flex-direction:column;gap:.75rem}.project-title{font-size:1rem;font-weight:600;color:var(--text);margin:0 0 .35rem;letter-spacing:-.01em}.project-title-link{color:inherit;text-decoration:none;transition:color var(--transition-fast);display:inline-block;padding:.25rem 0;border-radius:2px}.project-title-link:hover{color:var(--color-primary);text-decoration:underline}.project-title-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.project-header{display:flex;flex-direction:column;gap:0;margin-bottom:0}.project-header .project-title{margin-bottom:0}.project-year{font-size:.7rem;color:var(--color-gray-light);margin-top:2px;margin-bottom:6px;display:block;font-weight:500;letter-spacing:.03em}.project-featured-star{position:absolute;top:14px;right:14px;font-size:20px;z-index:1}.project-description{color:var(--muted);font-size:.75rem;line-height:1.35;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.key-features{margin:0 0 1.25rem;padding-left:1.25rem;list-style-type:disc}.key-features li{color:var(--muted);font-size:.875rem;line-height:1.6;margin-bottom:.375rem}.key-features li:last-child{margin-bottom:0}.learning-section{margin:0 0 1.25rem;padding-top:.75rem;border-top:1px solid var(--border)}.learning-title{font-size:.8125rem;font-weight:600;color:var(--muted);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.03em}.learning-highlights{margin:0;padding-left:1.25rem;list-style-type:disc}.learning-highlights li{color:var(--muted);font-size:.8125rem;line-height:1.55;margin-bottom:.25rem}.learning-highlights li:last-child{margin-bottom:0}.tech-stack{display:flex;flex-wrap:wrap;gap:.2rem;margin-bottom:0}.tech-tag{background-color:var(--surface-2);color:var(--text);padding:.1rem .4rem;border-radius:var(--radius-full);font-size:.65rem;font-weight:500;border:1px solid var(--border);transition:background-color var(--transition-fast)}.project-actions{display:flex;flex-direction:column;gap:.375rem;margin-top:auto}.project-links{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.project-link-placeholder{visibility:hidden}.project-link{padding:.3rem .4rem;border-radius:var(--radius-full);text-decoration:none;font-weight:500;font-size:.7rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;white-space:nowrap;min-width:0}.project-link:hover{transform:translateY(-1px)}.github-link,.server-link{background-color:var(--surface-2);color:var(--text);border:1px solid var(--border)}.github-link:hover,.server-link:hover{background-color:var(--surface);border-color:var(--muted);box-shadow:var(--shadow-sm)}.demo-link{background-color:var(--color-primary);color:var(--bg);border:1px solid var(--color-primary);font-weight:600}.demo-link:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-sm)}.demo-link:focus-visible,.github-link:focus-visible,.server-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.view-details-link{display:flex;align-items:center;justify-content:center;padding:.3rem .4rem;border-radius:var(--radius-full);background-color:var(--accent-soft);color:var(--color-primary);border:1px solid var(--color-primary);font-weight:500;font-size:.7rem;text-decoration:none;text-align:center;white-space:nowrap;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast);cursor:pointer;width:calc((100% - (2 * .5rem)) / 3);align-self:flex-start}.view-details-link:hover{background-color:var(--color-primary);color:var(--bg);border-color:var(--color-primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.view-details-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}@media (max-width: 480px){.project-content{padding:.75rem}.project-links{grid-template-columns:repeat(3,1fr)}}.home{min-height:calc(100vh - 200px)}.hero{max-width:720px;margin:0 auto;padding:1.25rem var(--page-padding) 1rem;text-align:center}.hero-logo{height:64px;width:auto;display:block;margin:0 auto 10px}.hero-greeting{font-size:1rem;color:var(--color-primary);margin:0 0 .75rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.hero-name{font-size:clamp(2.5rem,6vw,3.5rem);font-weight:700;color:var(--text);margin:0 0 .75rem;letter-spacing:-.03em;line-height:1.1}.hero-title{font-size:clamp(1.125rem,3vw,1.5rem);font-weight:400;color:var(--muted);margin:0 0 2rem}.hero-headline{font-size:1.125rem;font-weight:500;line-height:1.65;color:var(--text);margin:0 0 1rem;max-width:560px;margin-left:auto;margin-right:auto}.hero-description{font-size:1.0625rem;line-height:1.75;color:var(--muted);margin:0 0 1rem;max-width:560px;margin-left:auto;margin-right:auto}.hero-statement{font-size:.9375rem;color:var(--muted);font-style:italic;margin:0 0 2.5rem;opacity:.85}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:0}.hero-cta-btn{width:220px;text-align:center}.btn{padding:.875rem 2rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9375rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:inline-block;cursor:pointer}.btn-primary{background-color:var(--color-primary);color:var(--bg);border:1px solid var(--color-primary);box-shadow:var(--shadow-sm);font-weight:600}.btn-secondary{background-color:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background-color:var(--surface-2);border-color:var(--muted);box-shadow:var(--shadow-md)}.home .skills-preview{padding:0;margin-top:12px;margin-bottom:1.25rem;text-align:center}.home .skills-title{font-size:.8125rem;font-weight:700;color:var(--color-primary);margin:0 0 .625rem;text-transform:uppercase;letter-spacing:.06em;position:relative;display:inline-block}.home .skills-title:after{content:"";display:block;width:40px;height:2px;background-color:var(--color-primary);margin:.3rem auto 0;border-radius:1px;opacity:.6}.home .skills-grid{display:flex;flex-wrap:nowrap;justify-content:center;align-items:center;gap:.6rem;margin:0 auto;list-style:none;padding:0}.home .skill-item{display:flex;flex-direction:column;align-items:center;gap:.2rem;min-width:0}.home .skill-icon{width:24px;height:24px;object-fit:contain}.home .skill-name{font-size:.55rem;font-weight:600;color:var(--muted);text-align:center;line-height:1.2;white-space:nowrap;letter-spacing:.06em;text-transform:uppercase}.featured-projects{padding:1.5rem var(--page-padding) 1rem;max-width:var(--container-max);margin:0 auto}.featured-title{font-size:.8125rem;font-weight:600;color:var(--muted);text-align:center;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.featured-cta{text-align:center;margin-top:1rem}.more-projects{padding:.75rem var(--page-padding) 1.5rem;max-width:var(--container-max);margin:0 auto}.more-projects-title{font-size:.8125rem;font-weight:600;color:var(--muted);text-align:center;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.more-projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}@media (max-width: 899px){.home .skills-grid{flex-wrap:wrap;justify-content:center}}@media (max-width: 768px){.hero{padding:1.25rem var(--page-padding) 2.5rem}.hero-name{font-size:2.25rem}.hero-title{font-size:1.125rem}.hero-description{font-size:1rem}.featured-projects{padding:1.25rem var(--page-padding) .75rem}.more-projects{padding:.75rem var(--page-padding) 1.5rem}.hero-logo{height:52px}}@media (max-width: 480px){.hero-buttons{flex-direction:column;align-items:center}.btn{width:100%;max-width:250px;text-align:center}.skills-grid{flex-wrap:wrap;gap:.5rem}}.about{min-height:calc(100vh - 200px);background-color:var(--bg)}.about-container{max-width:720px;margin:0 auto;padding:1.25rem var(--page-padding) 3.5rem}.about .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 1rem;text-align:center;letter-spacing:-.02em}.about-section{margin-bottom:2.75rem}.about-section:last-child{margin-bottom:0}.section-title{font-size:1.25rem;font-weight:600;color:var(--text);margin:0 0 1.25rem;padding-bottom:.625rem;border-bottom:2px solid var(--color-primary);display:inline-block}.about-text{font-size:1rem;line-height:1.75;color:var(--muted);margin:0 0 .75rem}.about-text:last-child{margin-bottom:0}.experience-entry{margin-bottom:1.5rem}.experience-entry:last-child{margin-bottom:0}.experience-entry h3{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.experience-list{margin:.5rem 0 0;padding-left:1.25rem;list-style-type:disc}.experience-list li{color:var(--muted);font-size:.9375rem;line-height:1.7;margin-bottom:.25rem}.experience-list li:last-child{margin-bottom:0}.education-entry{margin-bottom:1.25rem}.education-entry:last-child{margin-bottom:0}.education-entry h3{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.education-list{margin:.5rem 0 0;padding-left:1.25rem;list-style-type:disc}.education-list li{color:var(--muted);font-size:.9375rem;line-height:1.7;margin-bottom:.25rem}.education-list li:last-child{margin-bottom:0}.certification-entry{margin-bottom:1.25rem}.certification-entry:last-child{margin-bottom:0}.certification-entry h3{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 .25rem}.institution{font-size:.9375rem;color:var(--color-primary);margin:0;font-weight:500}.languages-list{list-style:none;padding:0;margin:0}.languages-list li{color:var(--muted);font-size:.9375rem;line-height:1.7;padding:.125rem 0}@media (max-width: 768px){.about-container{padding:1.25rem var(--page-padding) 2.75rem}.about .page-title{font-size:2rem}.section-title{font-size:1.125rem}.about-text{font-size:.9375rem}.about-section{margin-bottom:2.25rem}}.projects{min-height:calc(100vh - 200px);background-color:var(--bg)}.projects-container{max-width:var(--container-max);margin:0 auto;padding:1.25rem var(--page-padding) 2.75rem}.projects .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 1rem;text-align:center;letter-spacing:-.02em}.filters-wrapper{text-align:center;margin-bottom:1.25rem}.filters-toggle-btn{display:inline-flex;align-items:center;gap:.4rem;background-color:var(--surface);color:var(--text);border:1px solid var(--border);padding:.4rem 1rem;border-radius:var(--radius-full);font-weight:600;font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.filters-toggle-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--accent-soft)}.filters-toggle-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.filters-caret{font-size:.75rem;transition:transform var(--transition-fast);display:inline-block}.filters-caret.open{transform:rotate(180deg)}.filters-panel{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-top:.625rem;padding:.75rem 1rem;background-color:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.filters-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:.3rem}.filter-chip{background-color:var(--surface-2);color:var(--muted);border:1px solid var(--border);padding:.2rem .6rem;border-radius:var(--radius-full);font-weight:500;font-size:.725rem;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.filter-chip:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:var(--accent-soft)}.filter-chip.active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--bg);font-weight:600}.filter-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.filters-clear-btn{background:none;border:none;color:var(--color-primary);font-size:.725rem;font-weight:600;cursor:pointer;padding:.15rem .5rem;border-radius:var(--radius-sm, 4px);transition:all var(--transition-fast)}.filters-clear-btn:hover{background-color:var(--accent-soft);text-decoration:underline}.filters-clear-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;grid-auto-rows:1fr}.projects .project-description{-webkit-line-clamp:unset;display:block;overflow:visible}.projects .project-card-top{min-height:50px}.projects .project-card-bottom{margin-top:0;flex:1}.no-results{text-align:center;color:var(--muted);font-size:1.0625rem;padding:3rem 1rem}@media (max-width: 768px){.projects-container{padding:1.25rem var(--page-padding) 2.75rem}.projects .page-title{font-size:2rem}.projects-grid{grid-template-columns:1fr}}.project-details{min-height:calc(100vh - 200px);background-color:var(--bg)}.project-details-container{max-width:800px;margin:0 auto;padding:4rem var(--page-padding)}.details-header{margin-bottom:2rem;text-align:center}.details-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0;letter-spacing:-.02em}.details-year{font-size:.875rem;font-weight:500;color:var(--muted);margin:.25rem 0 0;letter-spacing:.02em}.details-image-container{margin-bottom:2rem;background-color:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);display:flex;justify-content:center;align-items:center}.project-image-full{width:100%;height:200px;object-fit:contain;border-radius:var(--radius-lg);display:block}.project-detail-image-link{display:block;cursor:pointer}.details-section{margin-bottom:2rem;background-color:var(--surface);padding:1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border)}.details-section-title{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-primary);display:inline-block}.details-description{font-size:1rem;line-height:1.75;color:var(--muted);margin:0}.details-list{margin:0;padding-left:1.5rem;list-style-type:disc}.details-list li{color:var(--muted);font-size:.9375rem;line-height:1.7;margin-bottom:.5rem}.details-list li:last-child{margin-bottom:0}.details-tech-stack{display:flex;flex-wrap:wrap;gap:.5rem}.details-tech-tag{background-color:var(--surface-2);color:var(--text);padding:.375rem .875rem;border-radius:var(--radius-full);font-size:.8125rem;font-weight:500;border:1px solid var(--border)}.details-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2.5rem}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-full);text-decoration:none;font-weight:600;font-size:.9375rem;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast);display:inline-block;cursor:pointer}.btn:hover{transform:translateY(-2px)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.btn-primary{background-color:var(--color-primary);color:var(--bg);border:1px solid var(--color-primary)}.btn-primary:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background-color:var(--surface-2);border-color:var(--muted);box-shadow:var(--shadow-sm)}.details-back{padding-top:1.5rem;border-top:1px solid var(--border)}.back-link{color:var(--color-primary);font-weight:500;font-size:.9375rem;text-decoration:none;transition:color var(--transition-fast),text-decoration var(--transition-fast);display:inline-block;padding:.25rem 0;border-radius:2px}.back-link:hover{color:var(--color-primary-light);text-decoration:underline}.back-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft)}.not-found{text-align:center;padding:4rem 0}.not-found-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;color:var(--text);margin:0 0 1rem}.not-found-text{color:var(--muted);font-size:1rem;margin:0 0 2rem}@media (max-width: 768px){.project-image-full{height:150px}}@media (max-width: 480px){.project-details-container{padding:2rem var(--page-padding)}.details-section{padding:1.25rem}.details-actions{flex-direction:column}.btn{text-align:center;width:100%}}.contact-page{min-height:calc(100vh - 200px);background-color:var(--bg)}.contact-container{max-width:680px;margin:0 auto;padding:1.25rem var(--page-padding) 2.75rem;text-align:center}.contact-page .page-title{font-size:clamp(2rem,5vw,2.5rem);font-weight:700;color:var(--text);margin:0 0 1rem;text-align:center;letter-spacing:-.02em}.contact-page .page-description{display:flex;flex-direction:column;gap:.25rem;margin-bottom:2rem}.contact-page .page-description p{margin:0}.contact-grid{display:grid;grid-template-columns:1fr;gap:1rem}.contact-card{display:flex;align-items:flex-start;gap:1rem;background-color:var(--surface);padding:1.25rem 1.5rem;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:left;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.contact-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.contact-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:40px;height:40px;border-radius:var(--radius-lg);background-color:var(--bg);color:var(--color-primary)}.contact-icon svg{width:20px;height:20px}.contact-text{min-width:0}.contact-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .25rem}.contact-link{font-size:.9375rem;color:var(--text);text-decoration:none;font-weight:500;word-break:break-all;transition:color var(--transition-fast)}.contact-link:hover{color:var(--color-primary);text-decoration:underline}.contact-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:2px}.contact-value{font-size:.9375rem;color:var(--text);font-weight:500}.contact-value-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.copy-btn{font-size:.75rem;font-weight:500;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.2rem .55rem;cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.copy-btn:hover{color:var(--color-primary);border-color:var(--color-primary)}.copy-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-lg)}.copy-feedback{font-size:.75rem;color:var(--color-primary);font-weight:500;white-space:nowrap}@media (max-width: 600px){.contact-container{padding:1.25rem var(--page-padding) 2.75rem}.contact-page .page-title{font-size:2rem}.contact-card{padding:1.25rem}}.app{display:flex;flex-direction:column;min-height:100vh}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2dd4bf;--color-primary-dark: #14b8a6;--color-primary-light: #5eead4;--accent-soft: rgba(45, 212, 191, .15);--accent-gradient: linear-gradient(135deg, #0d9488 0%, #0891b2 100%);--text: #e2e8f0;--muted: #94a3b8;--color-dark: #e2e8f0;--color-gray: #94a3b8;--color-gray-light: #64748b;--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--border: rgba(148, 163, 184, .15);--color-background: #1e293b;--color-white: #f8fafc;--container-max: 1120px;--page-padding: clamp(1rem, 3vw, 1.5rem);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2), 0 1px 3px rgba(0, 0, 0, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .25), 0 2px 4px -2px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -4px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .3), 0 8px 10px -6px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.7;color:var(--text);background-color:var(--bg);background-image:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(45,212,191,.04),transparent)}h1,h2,h3,h4,h5,h6{line-height:1.3;font-weight:600;color:var(--text)}h1{font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.02em}h2{font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.01em}h3{font-size:clamp(1.125rem,2vw,1.375rem)}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}a:focus-visible,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;box-shadow:0 0 0 4px var(--accent-soft);border-radius:var(--radius-sm)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}::selection{background-color:var(--accent-soft);color:var(--color-primary)}.page-description{font-size:.925rem;color:var(--muted);text-align:center;max-width:800px;margin-left:auto;margin-right:auto;margin-bottom:1rem;line-height:1.5;width:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{transition:none!important;animation:none!important}html{scroll-behavior:auto!important}.project-card:hover{transform:none!important}}
