.projects-page{position:relative;overflow:hidden}.projects-page:before{content:"";position:absolute;inset:0 0 auto 0;height:520px;background:radial-gradient(circle at 50% -10%,rgba(var(--color-accent-rgb),.12),transparent 60%);pointer-events:none;z-index:-1}.projects-hero{padding:clamp(3.5rem,8vw,6rem) 0 2.5rem}.projects-hero__title{margin:.75rem 0 0;font-size:clamp(2.75rem,8vw,4.5rem);line-height:1.02;letter-spacing:-.02em;color:var(--color-dark,#0f172a)}.projects-hero__subtitle{max-width:46rem;margin:1.1rem 0 0;font-size:clamp(1rem,2.2vw,1.15rem);line-height:1.6;color:var(--color-muted,#475569)}.projects-controls{margin-top:2.5rem;display:flex;flex-direction:column;gap:1.25rem}.projects-segment{display:inline-flex;align-self:flex-start;max-width:100%;flex-wrap:wrap;gap:.3rem;padding:.35rem;border-radius:999px;background:rgba(var(--color-white-rgb),.5);border:1px solid rgba(var(--color-accent-rgb),.22);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.projects-segment .segment{padding:.5rem 1.15rem;border:none;border-radius:999px;background:transparent;color:var(--color-muted,#475569);font-size:.88rem;font-weight:600;cursor:pointer;transition:color .2s ease,background .2s ease,box-shadow .2s ease}.projects-segment .segment:hover{color:var(--color-dark,#0f172a)}.projects-segment .segment.is-active{color:#051016;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));box-shadow:0 8px 20px -10px rgba(var(--color-accent-rgb),.7)}.projects-grid-section{padding:1rem 0 clamp(4rem,8vw,6rem)}.projects-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:clamp(1.25rem,3vw,2rem);gap:clamp(1.25rem,3vw,2rem)}.projects-empty{padding:3rem 0;text-align:center;color:var(--color-muted,#475569)}.project-card{position:relative;display:flex;flex-direction:column;border-radius:20px;overflow:hidden;background:linear-gradient(155deg,rgba(var(--color-white-rgb),.72),rgba(var(--color-white-rgb),.42));backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(var(--color-accent-rgb),.2);box-shadow:0 18px 42px -30px rgba(var(--color-dark-rgb),.6);transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease}.project-card:focus-within,.project-card:hover{transform:translateY(-6px);border-color:rgba(var(--color-accent-rgb),.5);box-shadow:0 28px 60px -30px rgba(var(--color-accent-rgb),.5),0 0 22px -8px rgba(var(--color-accent-rgb),.35)}.project-card__overlay{position:absolute;inset:0;z-index:2;padding:0;border:none;background:transparent;cursor:pointer}.project-card__overlay:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:20px}.project-card__media{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:rgba(var(--color-primary-rgb),.08)}.project-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.project-card:focus-within .project-card__media img,.project-card:hover .project-card__media img{transform:scale(1.06)}.project-card__body{display:flex;flex-direction:column;gap:1rem;padding:1.6rem}.project-card__badges{display:flex;flex-wrap:wrap;gap:.45rem}.project-card__heading h3{margin:0;font-size:1.3rem;line-height:1.2;color:var(--color-dark,#0f172a);transition:color .2s ease}.project-card:focus-within .project-card__heading h3,.project-card:hover .project-card__heading h3{color:var(--color-primary)}.project-card__tagline{margin:.3rem 0 0;font-size:.9rem;font-weight:500;color:var(--color-primary)}.project-card__summary{margin:0;color:var(--color-muted,#475569);line-height:1.6;font-size:.92rem}.project-card__responsibilities{display:flex;flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none}.project-card__responsibilities li{display:flex;align-items:flex-start;gap:.55rem;font-size:.88rem;line-height:1.5;color:var(--color-muted,#475569)}.project-card__responsibilities svg{flex-shrink:0;margin-top:.15rem;width:.95rem;height:.95rem;color:var(--color-accent)}.project-card__tech{display:flex;flex-wrap:wrap;gap:.45rem}.project-card__tech span{font-size:.72rem;font-weight:600;padding:.28rem .65rem;border-radius:999px;color:var(--color-primary,#2563eb);background:rgba(var(--color-primary-rgb),.1);border:1px solid transparent;transition:color .2s ease,background .2s ease,border-color .2s ease}.project-card:focus-within .project-card__tech span,.project-card:hover .project-card__tech span{background:rgba(var(--color-accent-rgb),.16);border-color:rgba(var(--color-accent-rgb),.4);color:var(--color-dark,#0f172a)}.project-card__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(6rem,1fr));grid-gap:.6rem;gap:.6rem;margin-top:auto;padding-top:.35rem}.status-badge{font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.22rem .6rem;border-radius:999px;border:1px solid transparent;color:var(--color-dark,#0f172a);background:rgba(var(--color-muted-rgb),.16)}.status-badge.is-production{color:#0b3d2e;background:rgba(16,185,129,.18);border-color:rgba(16,185,129,.4)}.status-badge.is-client{color:#062a3d;background:rgba(var(--color-accent-rgb),.2);border-color:rgba(var(--color-accent-rgb),.45)}.status-badge.is-freelance{color:#3a2a05;background:rgba(245,179,66,.2);border-color:rgba(245,179,66,.45)}.status-badge.is-personal{color:#2a1547;background:rgba(139,92,246,.2);border-color:rgba(139,92,246,.45)}.status-badge.is-oss{color:#07304a;background:rgba(var(--color-primary-rgb),.18);border-color:rgba(var(--color-primary-rgb),.4)}.status-badge.is-ai{color:#3d0733;background:rgba(236,72,153,.2);border-color:rgba(236,72,153,.45)}[data-theme=dark] .status-badge{color:var(--color-dark,#0f172a)}[data-theme=dark] .status-badge.is-production{color:#6ee7b7}[data-theme=dark] .status-badge.is-client{color:var(--color-accent)}[data-theme=dark] .status-badge.is-freelance{color:#fbbf24}[data-theme=dark] .status-badge.is-personal{color:#c4b5fd}[data-theme=dark] .status-badge.is-oss{color:var(--color-primary)}[data-theme=dark] .status-badge.is-ai{color:#f9a8d4}.metric{display:flex;flex-direction:column;gap:.15rem;padding:.75rem .85rem;border-radius:12px;background:rgba(var(--color-accent-rgb),.08);border:1px solid rgba(var(--color-accent-rgb),.18)}.metric__value{font-size:1.25rem;font-weight:700;line-height:1;color:var(--color-dark,#0f172a)}.metric__label{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted,#475569)}.project-modal{position:fixed;inset:0;z-index:100;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:clamp(1rem,5vw,3rem);background:rgba(2,6,16,.7);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.project-modal__panel{position:relative;width:min(880px,100%);margin:0 auto;border-radius:24px;overflow:hidden;background:var(--surface-card);border:1px solid rgba(var(--color-accent-rgb),.3);box-shadow:0 40px 90px -40px rgba(0,0,0,.8)}.project-modal__close{position:absolute;top:1rem;right:1rem;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;border:none;border-radius:50%;background:rgba(2,6,16,.55);color:#fff;cursor:pointer;transition:background .2s ease,transform .2s ease}.project-modal__close:focus-visible,.project-modal__close:hover{background:rgba(2,6,16,.8);transform:scale(1.05)}.project-modal__hero{overflow:hidden;background:rgba(var(--color-dark-rgb),.06);border-bottom:1px solid var(--border-subtle)}.project-modal__hero img{display:block;width:100%;height:auto;max-height:60vh;object-fit:contain}.project-modal__content{padding:clamp(1.5rem,4vw,2.5rem)}.project-modal__content h2{margin:.6rem 0 0;font-size:clamp(1.6rem,4vw,2.1rem);line-height:1.15;color:var(--color-dark,#0f172a)}.project-modal__badges{display:flex;flex-wrap:wrap;gap:.45rem}.project-modal__tagline{margin:.5rem 0 0;font-size:1rem;font-weight:500;color:var(--color-primary)}.project-modal__meta{display:flex;flex-wrap:wrap;gap:1.25rem;margin-top:1rem;font-size:.85rem;color:var(--color-muted,#475569)}.project-modal__meta strong{color:var(--color-dark,#0f172a);font-weight:600}.project-modal__section{margin-top:2rem}.project-modal__section h3{margin:0 0 .85rem;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent)}.project-modal__section p{margin:0;color:var(--color-muted,#475569);line-height:1.7}.project-modal__list{display:flex;flex-direction:column;gap:.7rem;margin:0;padding:0;list-style:none}.project-modal__list li{display:flex;align-items:flex-start;gap:.6rem;color:var(--color-muted,#475569);line-height:1.6}.project-modal__list svg{flex-shrink:0;margin-top:.2rem;width:1rem;height:1rem;color:var(--color-accent)}.project-modal__tech{display:flex;flex-wrap:wrap;gap:.5rem}.project-modal__tech span{font-size:.78rem;font-weight:600;padding:.35rem .8rem;border-radius:999px;color:var(--color-primary,#2563eb);background:rgba(var(--color-primary-rgb),.12);border:1px solid rgba(var(--color-primary-rgb),.2)}.project-modal__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(7rem,1fr));grid-gap:.75rem;gap:.75rem}.project-modal__diagram{width:100%;border-radius:14px;border:1px solid var(--border-subtle)}.project-modal__gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:.85rem;gap:.85rem}.project-modal__gallery img{width:100%;border-radius:14px;border:1px solid var(--border-subtle)}.project-modal__actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2.25rem}.project-modal__link{display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 1.1rem;border-radius:999px;font-size:.85rem;font-weight:600;text-decoration:none;color:var(--color-dark,#0f172a);background:rgba(var(--color-accent-rgb),.12);border:1px solid rgba(var(--color-accent-rgb),.3);transition:background .2s ease,transform .2s ease}.project-modal__link svg{width:1rem;height:1rem}.project-modal__link:hover:not(.is-disabled){transform:translateY(-1px);background:rgba(var(--color-accent-rgb),.22)}.project-modal__link.is-disabled{opacity:.4;cursor:not-allowed}@media(max-width:640px){.projects-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.project-card,.project-card__media img,.project-card__tech span,.segment{transition:none}}