body{margin:0;font-family:-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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--page-bg: #f3f4ef;--surface: #fdfbf6;--surface-strong: #fffdf7;--ink: #1d1f22;--muted: #4d5258;--edge: #c8c7bf;--edge-strong: #25272b;--accent: #0f5e59;--overlay: rgba(12, 13, 15, .38)}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at 20% -15%,#ffffff 8%,var(--page-bg) 40%,#e8e9df 100%);color:var(--ink)}.portfolio-page{min-height:100vh;padding:1.5rem 0 4rem}.site-header{display:flex;justify-content:center;align-items:center;min-height:20vh;padding:1rem}.site-title{margin:0;font-size:clamp(2.1rem,4.8vw,3.6rem);letter-spacing:.06em;text-transform:uppercase}.project-list{display:flex;flex-direction:column;align-items:center;gap:1rem;padding-bottom:4rem}.project-card{width:min(80%,980px);border:1px solid var(--edge);border-radius:16px;padding:1.25rem 1.4rem;background:var(--surface);box-shadow:0 8px 20px #0000000f;display:flex;flex-direction:column;gap:.75rem}.project-card-content{display:flex;flex-direction:column;gap:.75rem;height:100%}.project-card-fixed{height:auto}.project-card-fixed .project-card-content{display:grid;grid-template-columns:minmax(0,1fr) clamp(200px,28%,300px);column-gap:1rem;align-items:start}.project-card-copy{flex:1 1 auto;display:flex;flex-direction:column;gap:.75rem;min-height:0}.project-card h2{margin:0;font-size:1.35rem}.project-card p{margin:0;color:var(--muted);line-height:1.5}.project-title-image{width:100%;height:96px;display:block;align-self:center;object-fit:cover;object-position:center;border:1px solid var(--edge);border-radius:10px;background:#eff1eb}.details-button{align-self:flex-start;border:1px solid var(--edge-strong);background:transparent;color:var(--edge-strong);border-radius:999px;padding:.55rem .95rem;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .18s ease,color .18s ease}.details-button:hover{background:var(--edge-strong);color:#fff}.project-link-line{margin:0;color:var(--muted);font-size:.92rem}.project-link{color:var(--accent);text-decoration:none}.project-link:hover{text-decoration:underline}.details-button:focus-visible,.close-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.project-overlay{position:fixed;inset:0;background:var(--overlay);z-index:20}.project-expanded{position:fixed;display:flex;flex-direction:column;border:1px solid var(--edge-strong);border-radius:20px;background:var(--surface-strong);box-shadow:0 28px 60px #0003;overflow:hidden;transition:top .36s cubic-bezier(.19,1,.22,1),left .36s cubic-bezier(.19,1,.22,1),width .36s cubic-bezier(.19,1,.22,1),height .36s cubic-bezier(.19,1,.22,1),opacity .3s ease}.close-button{position:absolute;top:.85rem;left:.85rem;border:1px solid var(--edge-strong);background:#fff;color:var(--edge-strong);border-radius:999px;width:2.1rem;height:2.1rem;display:grid;place-items:center;font-weight:700;cursor:pointer}.expanded-content{display:flex;flex-direction:column;gap:1rem;padding:4rem 1.25rem 1.25rem;height:100%;overflow-y:auto}.expanded-content h2{margin:0}.expanded-content p{margin:0;color:var(--muted)}.expanded-copy{display:flex;flex-direction:column;gap:.8rem;margin-top:.25rem}.instruction-list{margin:0;padding-left:1.2rem;color:var(--muted)}.instruction-list li{margin-bottom:.45rem}.expanded-copy code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em;background:#fff;border:1px solid var(--edge);border-radius:6px;padding:.08rem .35rem}@media(max-width:768px){.site-header{min-height:16vh}.site-title{font-size:clamp(1.85rem,10vw,2.7rem)}.project-card{width:min(92%,980px);padding:1rem}.project-card-fixed{height:auto}.project-card-fixed .project-card-content{display:flex;flex-direction:column}.project-title-image{width:100%;height:150px}.project-card h2{font-size:1.2rem}}
