.project-card{display:flex;flex-direction:column;border-radius:0rem;background:var(--card);border:1px solid var(--border);box-shadow:0 1px 3px color-mix(in oklab,var(--text) 10%,transparent),inset 0 0 0 0 var(--accent);transition:box-shadow .2s ease;text-decoration:none;color:inherit;padding:1rem;overflow:hidden;font-family:var(--font-mono)}html[data-theme^=dark] .project-card{box-shadow:inset 0 0 0 0 var(--accent);border:1px solid var(--border)}.project-card:hover{box-shadow:0 1px 3px color-mix(in oklab,var(--text) 10%,transparent),inset 0 0 0 4px var(--accent)}html[data-theme^=dark] .project-card:hover{box-shadow:inset 0 0 0 4px var(--accent)}.project-card:focus-visible{box-shadow:0 1px 3px color-mix(in oklab,var(--text) 10%,transparent),inset 0 0 0 4px var(--accent)}html[data-theme^=dark] .project-card:focus-visible{box-shadow:inset 0 0 0 4px var(--accent)}.project-card img{width:100%;aspect-ratio:3 / 4;-o-object-fit:cover;object-fit:cover;margin-bottom:1rem;background:color-mix(in oklab,var(--bg) 85%,var(--text));display:block}.project-card h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text);line-height:1.3}.project-card p{margin:0 0 .375rem;color:var(--text);line-height:1.4;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.project-card .project-meta{display:flex;gap:1rem;margin:.25rem 0 0;font-size:.85rem;color:var(--text);font-weight:500}#projects-carousel{-ms-overflow-style:none;scrollbar-width:none}#projects-carousel::-webkit-scrollbar{display:none}@media (max-width: 640px){.project-card{padding:.9rem}.project-card img{aspect-ratio:3 / 4;margin-bottom:.75rem}.project-card h3{font-size:1.1rem}}.page-container{display:flex;align-items:center;justify-content:center;width:100%;min-height:calc(100dvh - 24px - var(--bottom-nav-height, 0px));padding:0 1rem;box-sizing:border-box}.carousel-wrapper{display:flex;align-items:center;gap:1rem;width:100%;max-width:1400px}.viewport{flex:1;overflow:hidden;position:relative;padding:.5rem 0}.track{display:flex;gap:1rem;width:100%;will-change:transform}.carousel-item{flex:0 0 calc((100% - 3rem)/4);width:calc((100% - 3rem)/4);min-width:0;box-sizing:border-box;height:auto;border:none;display:flex;flex-direction:column;align-items:flex-start}.carousel-item img{max-width:100%;align-self:center}@media (max-width: 768px){.carousel-item{flex:0 0 calc((100% - 1rem)/2);width:calc((100% - 1rem)/2)}}@media (max-width: 640px){.page-container{padding:0}.carousel-wrapper{position:relative;gap:0}.nav-btn{display:none}.viewport{padding:0;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;scroll-padding-left:12px;scroll-padding-right:12px}.viewport::-webkit-scrollbar{display:none}.viewport{scrollbar-width:none}.track{gap:.75rem;padding:0;transform:none!important;transition:none!important;will-change:auto}.track:before,.track:after{content:"";flex:0 0 12px}.carousel-item{flex:0 0 clamp(220px,72vw,320px);width:clamp(220px,72vw,320px);scroll-snap-align:start;scroll-snap-stop:always}}.nav-btn{background:var(--accent);color:#fff;border-radius:50%;padding:.5rem;transition:opacity .2s ease;flex-shrink:0;border:none;cursor:pointer;box-shadow:0 4px 6px #0000001a}.nav-btn:hover{opacity:.8}.nav-btn svg{width:1.5rem;height:1.5rem}.project-modal{position:fixed;inset:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:#0009;border:none;padding:0;margin:0;z-index:50;display:flex;align-items:center;justify-content:center;visibility:hidden;opacity:0;transition:opacity .2s ease,visibility .2s ease;color:#fff}.project-modal[open]{visibility:visible;opacity:1;display:flex}.project-modal::backdrop{background:#0009}.modal-inner{background:#000;width:86%;max-width:900px;height:auto;max-height:calc(100vh - 4rem);position:relative;border-radius:0;box-shadow:none;border:1px solid #222;display:flex;flex-direction:column;overflow:hidden}.modal-close-btn{position:absolute;top:0rem;right:0rem;background:transparent;border:none;cursor:pointer;z-index:20;width:40px;height:40px;border-radius:999px;display:grid;place-items:center;transition:transform .2s;padding:0}.modal-close-btn:before{content:"";width:12px;height:12px;border-radius:50%;background:#ff4733}.modal-close-btn:focus-visible{outline:2px solid #fff;outline-offset:2px}.modal-close-btn:hover{transform:scale(1.06)}.modal-close-btn:hover:before{background:#ff6b5c}.modal-content-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:0;width:100%;height:auto;min-height:0;align-items:start}.modal-media-col{background:#000;display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch;border-right:none;overflow:hidden;position:relative;padding:24px}.modal-media-header{width:100%;margin-bottom:1.25rem}.modal-media-header .modal-title{margin-bottom:0}.modal-media-footer{width:100%;margin-top:1.25rem}.modal-media-date{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;font-size:.9rem;color:#888}.gallery-slideshow{position:relative;width:min(520px,100%);aspect-ratio:4 / 3;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:#111;margin:0 auto}.slide-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;box-shadow:none;border-radius:0;transition:opacity .3s ease}.gallery-ctrl-btn{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:50%;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,transform .2s;z-index:10}.gallery-ctrl-btn:hover{background:#ffffff1a;transform:translateY(-50%) scale(1.1)}.gallery-ctrl-btn.prev{left:1rem}.gallery-ctrl-btn.next{right:1rem}.gallery-counter{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#0009;padding:.25rem .75rem;border-radius:1rem;font-size:.8rem;color:#ccc;font-family:var(--font-mono)}.modal-info-col{padding:2rem;display:flex;flex-direction:column;background:#000;overflow-y:auto;min-height:0;height:var(--modal-left-col-height, 70vh);max-height:var(--modal-left-col-height, 70vh)}.modal-info-col::-webkit-scrollbar{width:8px}.modal-info-col::-webkit-scrollbar-track{background:#111}.modal-info-col::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.modal-header{margin-bottom:1.5rem;flex-shrink:0}.modal-title-link{text-decoration:none;color:inherit;display:block}.modal-title-link:hover .modal-title{color:var(--accent)}.modal-title{font-family:var(--font-sans);font-size:2rem;font-weight:700;line-height:1.1;margin-bottom:1rem;color:#fff;transition:color .2s ease}@media (max-width: 900px){.modal-title{font-size:1.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}.modal-meta-row{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-mono);color:#888;font-size:.9rem;letter-spacing:.05em}.separator{height:1px;background:#222;margin-top:1.5rem;width:100%}.modal-description{flex:1;font-family:var(--font-sans);color:#ccc;font-size:1rem;line-height:1.6}.modal-description p{color:#ccc}.modal-description strong{color:#fff}.modal-description h3,.modal-description h4{color:#fff;margin-top:1.5em}.modal-footer{margin-top:2rem;padding-top:1rem;flex-shrink:0}.play-link{display:inline-flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-weight:500;font-family:var(--font-mono);border-bottom:1px solid white;padding-bottom:2px;transition:color .2s,border-color .2s}.play-link:hover{color:var(--accent);border-color:var(--accent)}@media (max-width: 900px){.project-modal{align-items:center;padding:12px;padding-bottom:calc(var(--bottom-nav-height, 0px) + 12px)}.modal-inner{width:calc(100% - 24px);height:auto;max-height:calc(100svh - var(--bottom-nav-height, 0px) - 24px);border-radius:0;border:none;overflow:auto;scrollbar-width:none}.modal-inner::-webkit-scrollbar{display:none}.modal-content-grid{grid-template-columns:1fr;grid-template-rows:auto 1fr;overflow:visible}.modal-media-col{height:auto;border-right:none;border-bottom:none;padding:0;overflow:visible}.modal-media-header{position:sticky;top:0;background:#000;padding:1rem 4rem 1rem 1.5rem;z-index:15;border-bottom:1px solid #222;margin:0;display:flex;align-items:center;justify-content:space-between}.modal-media-footer{padding:0rem 1.5rem}.gallery-slideshow{margin:1rem auto 0;padding:0 1.5rem;box-sizing:border-box;width:min(280px,80vw);aspect-ratio:16 / 9}.modal-info-col{padding:1.5rem;height:auto;overflow-y:visible}.modal-close-btn{display:none}}.lightbox-overlay{position:fixed;inset:0;z-index:9999;background:#000000f2;display:none;align-items:center;justify-content:center;border:none;width:100vw;height:100vh;max-width:100vw;max-height:100vh;margin:0;padding:0;color:#fff}.lightbox-overlay[open]{display:flex}.lightbox-overlay::backdrop{background:#000000f2}.lightbox-content img{max-width:95vw;max-height:95vh;-o-object-fit:contain;object-fit:contain}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;color:#fff;background:transparent;border:none;cursor:pointer;z-index:10000}.lightbox-close svg{width:2rem;height:2rem}.hidden{display:none!important}.icon-arrow{display:inline-block;vertical-align:middle;transform-origin:center}.rotate-left{transform:rotate(-90deg)}.rotate-right{transform:rotate(90deg)}
