@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Space+Grotesk:wght@400;500;700&display=swap";:root{color:#111;background:#080808;font-family:Space Grotesk,Trebuchet MS,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}html,body,#root{width:100%;height:100%}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100dvh;background:#080808;color:#111;overflow-x:hidden;overflow-y:auto}body,button,input{font-family:inherit}a{color:inherit;text-decoration:none}button,input{font:inherit}button,input,textarea{appearance:none;-webkit-appearance:none}img{display:block;max-width:100%}::selection{background:#d7d1c7;color:#000}.app-shell{min-height:100dvh;padding:14px;background:radial-gradient(circle at top,rgba(255,255,255,.05) 0,transparent 26%),#050505;color:#f3eee7}.portfolio{width:min(980px,100%);margin:0 auto;display:grid;gap:40px}.panel{padding:0 0 34px;border-bottom:1px solid #171717}.hero,.section-head,.stack-list,.focus-list,.contact-list,.project-list,.project-body,.project-visuals,.project-thumb-list,.project-detail-block,.project-specs{display:grid}.hero{gap:16px;padding-top:8px}.eyebrow,.action-link,.contact-label,.tag,.project-year,.skill-chip,.project-company,.project-detail-label,.project-spec dt{font-family:IBM Plex Mono,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.eyebrow{margin:0;color:#8e877e;font-weight:500}.hero-title,.section-title,.project-title,.focus-item h3{margin:0;font-family:Space Grotesk,sans-serif;font-weight:700;line-height:1;letter-spacing:.02em;text-transform:uppercase;color:#f3eee7}.hero-title{font-size:clamp(2.2rem,8vw,4.9rem)}.hero-copy,.project-summary,.project-points li,.focus-item p,.info-row p,.contact-value,.project-spec dd{margin:0;color:#b0a79b;line-height:1.65;overflow-wrap:anywhere}.hero-copy{max-width:58ch;font-size:.98rem}.hero-actions{display:flex;flex-wrap:wrap;gap:14px}.action-link{color:#f3eee7;text-decoration:none;padding:8px 12px;border:1px solid rgba(255,255,255,.14);border-radius:10px;background:#ffffff08;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);transition:border-color .2s ease,color .2s ease,background .2s ease,backdrop-filter .2s ease,transform .2s ease;display:inline-flex;align-items:center;gap:8px}.action-link:hover{border-color:#ffffff47;background:#ffffff14;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transform:translateY(-1px)}.section-grid{display:grid;gap:32px;align-items:start}.section-head{gap:10px;margin-bottom:18px}.section-title{font-size:clamp(1.45rem,4vw,2.1rem)}.stack-list,.focus-list,.contact-list{gap:0}.stack-list>*+*,.focus-list>*+*,.contact-list>*+*{margin-top:16px;padding-top:16px;border-top:1px solid #141414}.info-row{display:grid;grid-template-columns:auto minmax(0,1fr);gap:12px;align-items:start}.row-marker{width:6px;height:6px;margin-top:10px;border-radius:999px;background:#8e877e}.skill-list,.tag-list{display:flex;flex-wrap:wrap;gap:10px 14px}.skill-chip,.tag,.project-year{color:#d8d1c7}.project-list{gap:28px}.project-card{padding:0}.project-list>.project-card+.project-card{padding-top:28px;border-top:1px solid #171717}.project-layout{display:grid;gap:18px}.project-visuals{gap:12px}.project-visuals-gallery{grid-template-columns:minmax(0,1.6fr) minmax(0,.7fr);grid-template-rows:auto auto}.project-visual-primary{grid-row:span 2}.project-thumb-list{gap:12px;grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.project-visual{overflow:hidden;border-radius:14px;background:none;padding:0;border:none;cursor:zoom-in;min-height:160px}.project-visual-primary{min-height:320px}.project-visual-thumb{min-height:145px}.project-visual img{width:100%;display:block;aspect-ratio:16 / 10;object-fit:cover;background:transparent;filter:none;transition:transform .18s ease,opacity .18s ease}.project-visual:hover img{transform:scale(1.02);opacity:1}.project-body{gap:14px}.project-top{display:grid;gap:10px}.project-company{margin:0 0 8px;color:#8e877e;font-weight:500}.project-title{margin-bottom:8px;font-size:1.08rem}.project-detail-block{gap:10px}.project-detail-label{margin:0;color:#d8d1c7}.project-points{margin:0;padding-left:18px;display:grid;gap:8px}.project-points li::marker{color:#f3eee7}.project-specs{gap:12px;margin:0}.project-spec{display:grid;gap:4px}.project-spec dt{color:#d8d1c7}.focus-item{display:grid;gap:8px}.focus-item h3{font-size:.95rem;color:#f3eee7;margin-bottom:2px}.focus-item p{color:#b0a79b;font-size:.9rem;line-height:1.6}.contact-list{gap:0;display:grid}.contact-item{display:grid;gap:6px;color:inherit;text-decoration:none;transition:none;padding:0;border-radius:0;border:none;background:transparent}.contact-item:hover{background:transparent;border-color:transparent;transform:none}.contact-label{color:#8e877e;font-weight:500;font-size:.65rem;letter-spacing:.1em}.contact-value{color:#f3eee7;font-size:.95rem;font-weight:500}.contact-item:hover .contact-value{color:#f3eee7}.image-lightbox{position:fixed;inset:0;display:grid;place-items:center;padding:16px;background:#000000d6}.image-lightbox-panel{width:min(1080px,100%);max-height:92vh;display:grid;gap:14px}.image-lightbox-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#f3eee7;font-family:IBM Plex Mono,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.image-lightbox-close{border:0;padding:0;background:transparent;color:#f3eee7;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;border-bottom:1px solid #4a4a4a}.image-lightbox-close:hover{border-color:#f3eee7}.image-lightbox-actions{display:flex;align-items:center;gap:8px}.image-lightbox-zoom{border:0;padding:0;background:transparent;color:#f3eee7;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;border-bottom:1px solid #4a4a4a}.image-lightbox-zoom:hover{border-color:#f3eee7}.image-lightbox-image-wrap{width:100%;max-height:calc(92vh - 36px);overflow:auto;border-radius:14px;background:#0d0d0d;display:grid;place-items:center}.image-lightbox-image{width:100%;max-height:calc(92vh - 36px);object-fit:contain;border-radius:14px;background:#0d0d0d;transition:transform .15s ease;transform-origin:center center}a{color:inherit}button,a,input{-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible{outline:2px solid #5e5e5e;outline-offset:3px}.project-visuals-slider{position:relative;grid-template-columns:1fr}.project-slider-controls{display:contents}.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:2;background:#0a0a0a73;border:none;color:#f3eee7;width:26px;height:26px;border-radius:50%;font-size:.85rem;cursor:pointer;opacity:0;transition:opacity .2s ease,background .2s ease;touch-action:manipulation}.project-visuals-slider:hover .slider-btn,.project-visuals-slider:hover .slider-indicators{opacity:1}.slider-prev{left:10px}.slider-next{right:10px}.slider-btn:hover{background:#667eeacc}.slider-indicators{position:absolute;left:50%;bottom:10px;transform:translate(-50%);z-index:2;display:flex;gap:6px;align-items:center;opacity:0;transition:opacity .2s ease}.slider-dot{width:6px;height:6px;border-radius:50%;background:#667eea40;border:none;cursor:pointer;transition:all .2s ease;padding:0;touch-action:manipulation}.slider-dot:hover{background:#667eea80}.slider-dot.active{background:#667eea;width:10px;box-shadow:0 0 8px #667eea80}@media(hover:none),(pointer:coarse){.slider-btn,.slider-indicators{opacity:1}}@media(min-width:760px){.app-shell{padding:24px}.section-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-grid-bottom{grid-template-columns:1.05fr .95fr}.project-layout{grid-template-columns:minmax(260px,320px) minmax(0,1fr);align-items:start}.project-top{grid-template-columns:minmax(0,1fr) auto;align-items:start}}@media(max-width:759px){.portfolio{gap:32px}.hero-actions{display:grid;grid-template-columns:1fr;gap:10px}.action-link{width:fit-content}.project-visuals-gallery{grid-template-columns:1fr;grid-template-rows:auto}.project-visual-primary{grid-row:auto}.project-thumb-list{grid-template-columns:repeat(3,minmax(0,1fr))}.project-visuals-slider{grid-template-columns:1fr}}@media(max-width:480px){.app-shell{padding:10px}.portfolio{gap:28px}.panel{padding-bottom:26px}.hero-title{font-size:clamp(1.9rem,11vw,2.8rem)}.section-title{font-size:1.28rem}.project-visual img{aspect-ratio:16 / 11}.image-lightbox{padding:12px}.slider-btn{width:26px;height:26px;font-size:.9rem}.slider-dot{width:5px;height:5px}.slider-dot.active{width:9px}}
