/* ── Works — polaroid gallery view ── */

#view-works {
  background: var(--zine-bg);
  min-height: 100vh;
  padding: 0;
  overflow-y: auto;
}

.works-topbar {
  position: sticky; top: 0; z-index: 50;
  background: var(--zine-bg);
  border-bottom: 1px solid var(--win-border);
  padding: 10px 20px;
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 12px; color: var(--text-muted);
  backdrop-filter: blur(10px);
}
.works-back {
  cursor: pointer; color: var(--text-muted); text-decoration: none;
  background: none; border: none; font-family: var(--font-mono); font-size: 12px;
  padding: 6px 10px; border-radius: 4px;
  transition: background .15s, color .15s;
}
.works-back:hover, .works-back:focus-visible {
  color: var(--accent); background: var(--accent-dim); outline: none;
}

.works-body { padding: 28px 28px 100px; max-width: 1400px; margin: 0 auto; }

.works-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 28px; flex-wrap: wrap; gap: 16px;
}
.works-title {
  font-family: var(--font-display); font-size: 48px; line-height: 1; color: var(--text);
  margin-bottom: 4px;
}
.works-sub {
  font-family: var(--font-mono); font-size: 11px; color: var(--text-muted);
  letter-spacing: .5px;
}

/* Filter chips */
.filter-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.filter-chip {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .5px;
  text-transform: uppercase; padding: 6px 12px;
  border: 1px solid var(--win-border); border-radius: 4px;
  color: var(--text-muted); cursor: pointer; background: transparent;
  transition: background .15s, color .15s, border-color .15s;
}
.filter-chip:hover  { border-color: var(--accent); color: var(--accent); }
.filter-chip.active { background: var(--accent); border-color: var(--accent); color: #fff; }
.filter-chip:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* Polaroid grid */
.polaroid-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 28px;
  position: relative;
}

.polaroid-wrap {
  cursor: pointer;
  transition: transform .25s, filter .25s;
}
.polaroid-wrap:hover { transform: translateY(-4px); filter: brightness(1.05); }
.polaroid-wrap:focus-visible { outline: 2px solid var(--accent); outline-offset: 4px; }
.polaroid-wrap.hidden { display: none; }

.polaroid-inner {
  position: relative;
}

.polaroid-front {
  background: #fff; border: 1px solid rgba(0,0,0,.15);
  box-shadow: 2px 4px 14px rgba(0,0,0,.3);
  padding: 10px 10px 26px;
  position: relative;
}

.polaroid-img {
  width: 100%; aspect-ratio: 1;
  background: repeating-linear-gradient(135deg,rgba(0,0,0,.05) 0 4px,transparent 4px 8px);
  border: 1px solid rgba(0,0,0,.06);
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.polaroid-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.polaroid-glyph {
  font-size: 60px; color: #888;
  font-family: var(--font-display);
  user-select: none;
}

.polaroid-cap {
  font-family: var(--font-hand); font-size: 14px;
  color: #333; margin-top: 6px; text-align: center;
  font-weight: 500;
}

/* tape decoration */
.polaroid-tape {
  position: absolute; top: -8px; left: 50%; transform: translateX(-50%) rotate(-4deg);
  width: 52px; height: 16px; pointer-events: none;
  z-index: 2;
}

/* Works topbar window controls */
.works-topbar .win-controls { margin-left: 12px; }
.works-topbar .win-controls button { cursor: pointer; }

/* ── Project modal ── */
#project-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,.65);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: pmFadeIn .2s ease-out;
}
@keyframes pmFadeIn { from { opacity: 0; } to { opacity: 1; } }
.project-modal {
  background: var(--win-bg); color: var(--text);
  border: 1px solid var(--win-border);
  border-radius: 12px;
  max-width: 720px; width: 100%; max-height: 88vh;
  overflow-y: auto; position: relative;
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
  animation: pmSlideUp .25s ease-out;
}
@keyframes pmSlideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.project-modal-close {
  position: absolute; top: 12px; right: 12px; z-index: 5;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(0,0,0,.4); color: #fff; border: 1px solid rgba(255,255,255,.2);
  font-size: 22px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, transform .15s;
}
.project-modal-close:hover {
  background: var(--accent); border-color: var(--accent);
  transform: scale(1.1);
}
.project-modal-hero {
  width: 100%; aspect-ratio: 16/9;
  background: linear-gradient(135deg, var(--accent-dim), transparent);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  border-bottom: 1px solid var(--win-border);
}
.project-modal-hero img { width: 100%; height: 100%; object-fit: cover; }
.project-modal-glyph {
  font-family: var(--font-display); font-size: 100px; color: var(--accent);
}
.project-modal-body { padding: 28px 32px 32px; }
.pm-meta {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 2px; text-transform: uppercase; color: var(--accent);
  margin-bottom: 8px;
}
.pm-title {
  font-family: var(--font-display); font-size: 36px; line-height: 1.1;
  letter-spacing: -1px; color: var(--text); margin-bottom: 14px;
  font-weight: 400;
}
.pm-desc {
  font-family: var(--font-ui); font-size: 15px; line-height: 1.65;
  color: var(--text-muted); margin-bottom: 18px;
}
.pm-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 22px; }
.pm-tag {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .5px;
  padding: 4px 10px; border: 1px solid var(--win-border); border-radius: 3px;
  color: var(--text-muted);
}
.pm-cta { display: flex; flex-wrap: wrap; gap: 10px; }
.pm-btn {
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .3px;
  padding: 10px 18px; border-radius: 5px;
  text-decoration: none; cursor: pointer; transition: opacity .15s, transform .15s;
}
.pm-btn-primary {
  background: var(--accent); color: #fff; border: 1px solid var(--accent);
}
.pm-btn-primary:hover { opacity: .9; transform: translateY(-1px); }
.pm-btn-secondary {
  background: transparent; color: var(--text);
  border: 1px solid var(--win-border);
}
.pm-btn-secondary:hover { border-color: var(--accent); color: var(--accent); }
.pm-note {
  font-family: var(--font-mono); font-size: 11px; color: var(--text-muted);
  font-style: italic;
}

@media (max-width: 700px) {
  .pm-title { font-size: 26px; }
  .project-modal-body { padding: 20px; }
  .project-modal-hero { aspect-ratio: 4/3; }
}

/* ── Folder window grid ── */
.works-folder-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  padding: 16px;
}

.works-folder-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 14px 8px 10px;
  border-radius: 6px;
  cursor: default;
  user-select: none;
  transition: background .12s;
  outline: none;
}
.works-folder-item:hover {
  background: var(--accent-dim);
}
.works-folder-item:focus-visible {
  background: var(--accent-dim);
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}
.works-folder-item:active { background: rgba(255,90,60,.25); }

.wfi-icon {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.3));
  transition: transform .12s;
}
.wfi-icon img {
  width: 44px;
  height: 44px;
  object-fit: contain;
}
.works-folder-item:hover .wfi-icon { transform: scale(1.08) translateY(-1px); }

.wfi-name {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .3px;
  color: var(--text);
  text-align: center;
  line-height: 1.2;
}
.wfi-count {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--text-muted);
  letter-spacing: .5px;
}

/* ── Terminal cover (Myrtle card) ── */
.polaroid-terminal-cover {
  width: 100%;
  height: 100%;
  background: var(--term-bg);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px;
  gap: 6px;
  font-family: var(--font-mono);
}
.ptc-bar {
  display: flex;
  gap: 4px;
  align-self: flex-start;
  margin-bottom: 2px;
}
.ptc-dot {
  width: 7px; height: 7px; border-radius: 50%;
}
.ptc-dot:nth-child(1) { background: #ff5f57; }
.ptc-dot:nth-child(2) { background: #febc2e; }
.ptc-dot:nth-child(3) { background: #28c840; }
.ptc-prompt {
  align-self: flex-start;
  font-size: 9px;
  color: rgba(181,232,83,.5);
}
.ptc-text {
  font-size: 22px;
  letter-spacing: 6px;
  color: var(--term-text);
  text-transform: lowercase;
  text-shadow: 0 0 8px rgba(181,232,83,.5);
  animation: ptcPulse 2.5s ease-in-out infinite;
}
@keyframes ptcPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .7; }
}
.ptc-cursor {
  align-self: flex-start;
  font-size: 14px;
  color: var(--term-text);
  animation: ptcBlink 1s step-end infinite;
}
@keyframes ptcBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}

/* ── Figma embed in modal ── */
.pm-figma-wrap {
  padding: 0 32px 24px;
  border-bottom: 1px solid var(--win-border);
}
.pm-figma-label {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
  padding-top: 24px;
}
.pm-figma-wrap iframe {
  width: 100%;
  height: 480px;
  border: 1px solid var(--win-border);
  border-radius: 6px;
  display: block;
}
