/* ============================================================
   SHOWDOWN LAB — detail pages (projects + case studies)
   Builds on theme.css. Loaded only by /projects/* and /blog/*.
   ============================================================ */

/* ---------- hero ---------- */
.dhero { position: relative; padding-top: calc(var(--nav-h) + 64px); padding-bottom: 44px; overflow: hidden; }
.dhero canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.dhero .veil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(95% 90% at 30% 10%, transparent 28%, rgba(6,6,16,.7) 80%, var(--bg) 100%); }
.dhero .wrap { z-index: 2; }
.dhero .back { display: inline-flex; align-items: center; gap: .5em; font-family: var(--font-mono);
  font-size: .76rem; letter-spacing: .06em; color: var(--text-3); margin-bottom: 26px; transition: color .2s, gap .2s; }
.dhero .back:hover { color: var(--cyan); gap: .8em; }
.dhero .eyebrow-row { margin-bottom: 20px; }
.dhero h1 { font-size: clamp(2.5rem, 6vw, 4.6rem); font-weight: 500; letter-spacing: -.04em; line-height: .98; }
.dhero .sub { max-width: 640px; margin-top: 20px; }
.dhero .hero-cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.dmeta { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 26px; }
.live-dot { font-family: var(--font-mono); font-size: .62rem; letter-spacing: .16em; color: var(--green);
  display: inline-flex; align-items: center; gap: 7px; }
.live-dot::before { content:""; width:6px; height:6px; border-radius:50%; background: var(--green); box-shadow: 0 0 8px var(--green); }

/* ---------- big media ---------- */
.dmedia { position: relative; border-radius: var(--radius-lg); overflow: hidden;
  border: 1px solid var(--line-2); aspect-ratio: 16/8.6; margin-top: 8px;
  background: linear-gradient(135deg, rgba(139,92,246,.16), rgba(34,211,238,.09)); }
.dmedia img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }
.dmedia::after { content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, transparent 62%, rgba(8,8,18,.5)); }
.dmedia.placeholder::before { content: attr(data-label); position: absolute; inset: 0; z-index: 1;
  display: grid; place-items: center; font-family: var(--font-mono); font-size: .78rem; letter-spacing: .16em;
  text-transform: uppercase; color: var(--text-3); }

/* ---------- showcase gallery ---------- */
.showcase { position: relative; padding-bottom: 0; }
@media (min-width: 720px){ .showcase { padding-right: 70px; } }
.browser { border: 1px solid var(--line-2); border-radius: 14px; overflow: hidden;
  background: var(--surface); box-shadow: 0 40px 90px -45px rgba(0,0,0,.85); }
.browser .bbar { display: flex; align-items: center; gap: 7px; padding: 11px 14px;
  border-bottom: 1px solid var(--line); background: rgba(255,255,255,.03); }
.browser .bd { width: 11px; height: 11px; border-radius: 50%; background: #2a2a44; }
.browser .burl { margin-left: 12px; font-family: var(--font-mono); font-size: .74rem;
  letter-spacing: .02em; color: var(--text-3); }
.browser .bshot { aspect-ratio: 16 / 9.2; overflow: hidden; }
.browser .bshot img { width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }

/* phone mockup, overlapping the browser's lower-right on desktop */
.g-phone { width: 232px; border: 2px solid #20203a; border-radius: 30px; background: #0a0a14;
  padding: 8px; position: relative; box-shadow: 0 28px 60px -26px rgba(0,0,0,.85); }
.g-phone img { width: 100%; border-radius: 19px; display: block; }
.g-phone .g-notch { position: absolute; top: 13px; left: 50%; transform: translateX(-50%);
  width: 52px; height: 5px; border-radius: 4px; background: #20203a; z-index: 2; }
@media (min-width: 720px){
  .showcase .g-phone { position: absolute; right: -10px; bottom: -40px; width: 196px; z-index: 3; }
}
@media (max-width: 719px){ .showcase .g-phone { margin: 18px auto 0; } }

.g-strip { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px; }
@media (max-width: 560px){ .g-strip { grid-template-columns: 1fr; } }
.g-tile { border: 1px solid var(--line); border-radius: 12px; overflow: hidden;
  aspect-ratio: 16 / 10; background: var(--surface); }
.g-tile img { width: 100%; height: 100%; object-fit: cover; object-position: top center;
  display: block; transition: transform .6s cubic-bezier(.2,.8,.2,1); }
.g-tile:hover img { transform: scale(1.05); }

/* ---------- prose sections ---------- */
.dsection { padding-block: clamp(46px, 6vw, 80px); }
.dsection.tight { padding-block: clamp(34px, 4.5vw, 60px); }
.dgrid { display: grid; grid-template-columns: 280px 1fr; gap: clamp(28px, 5vw, 72px); align-items: start; }
@media (max-width: 820px){ .dgrid { grid-template-columns: 1fr; gap: 20px; } }
.dgrid .lbl { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--violet-2); padding-top: 6px; position: sticky; top: calc(var(--nav-h) + 20px); }
@media (max-width: 820px){ .dgrid .lbl { position: static; } }
.prose { max-width: 720px; }
.prose h2 { font-size: clamp(1.5rem, 2.6vw, 2.1rem); letter-spacing: -.025em; margin-bottom: 18px; }
.prose p { color: var(--text-2); font-size: 1.06rem; line-height: 1.7; margin-bottom: 16px; }
.prose p:last-child { margin-bottom: 0; }
.prose strong { color: var(--text); font-weight: 600; }
.prose .em { color: var(--violet-2); }

/* ---------- feature grid (what we built) ---------- */
.feat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (max-width: 680px){ .feat-grid { grid-template-columns: 1fr; } }
.feat { padding: 24px; }
.feat .chip { width: 42px; height: 42px; border-radius: 11px; margin-bottom: 16px; }
.feat .chip svg { width: 20px; height: 20px; }
.feat h3 { font-size: 1.1rem; margin-bottom: 8px; }
.feat p { color: var(--text-2); font-size: .94rem; line-height: 1.6; }

/* ---------- metrics ---------- */
.metric-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 18px; }
.metric { padding: 26px 24px; border: 1px solid var(--line); border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,.03), transparent); }
.metric .v { font-family: var(--font-display); font-size: clamp(2rem, 3.4vw, 2.9rem); font-weight: 500;
  letter-spacing: -.03em; line-height: 1; background: var(--grad); -webkit-background-clip: text;
  background-clip: text; -webkit-text-fill-color: transparent; }
.metric .l { color: var(--text-3); font-size: .9rem; margin-top: 12px; line-height: 1.4; }

/* ---------- stack chips ---------- */
.stack { display: flex; flex-wrap: wrap; gap: 9px; }
.stack span { font-family: var(--font-mono); font-size: .76rem; letter-spacing: .03em; color: var(--text-2);
  padding: 7px 13px; border-radius: 8px; border: 1px solid var(--line-2); background: rgba(255,255,255,.02); }

/* ---------- offer block (get your own) ---------- */
.offer { position: relative; border-radius: var(--radius-lg); overflow: hidden; padding: clamp(34px, 5vw, 60px);
  border: 1px solid rgba(139,92,246,.34);
  background: linear-gradient(160deg, rgba(139,92,246,.12), rgba(34,211,238,.05)); }
.offer::before { content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(70% 90% at 0% 0%, rgba(139,92,246,.22), transparent 60%); }
.offer .inner { position: relative; max-width: 760px; }
.offer h2 { font-size: clamp(1.7rem, 3.2vw, 2.5rem); margin-bottom: 16px; }
.offer p { color: var(--text-2); font-size: 1.06rem; line-height: 1.65; margin-bottom: 22px; }
.offer ul { list-style: none; margin: 0 0 28px; padding: 0; display: grid; gap: 11px; }
.offer li { display: flex; align-items: flex-start; gap: 11px; color: var(--text); font-size: 1rem; }
.offer li svg { width: 19px; height: 19px; flex: none; margin-top: 3px; stroke: var(--cyan); fill: none; stroke-width: 1.9; }
.offer .hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }

/* ---------- why showdown lab (agency pitch) ---------- */
.why-sl { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 880px){ .why-sl { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px){ .why-sl { grid-template-columns: 1fr; } }
.why-sl .why-card { padding: 26px; }
.why-sl .ix { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .16em; color: var(--violet-2); margin-bottom: 14px; }
.why-sl h3 { font-size: 1.08rem; margin-bottom: 8px; }
.why-sl p { color: var(--text-2); font-size: .92rem; line-height: 1.6; }
.why-foot { margin-top: 26px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: .8rem; color: var(--text-3); }
.why-foot .sep { width: 5px; height: 5px; border-radius: 50%; background: var(--text-4); }

/* ---------- related ---------- */
.rel-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 820px){ .rel-grid { grid-template-columns: 1fr; } }
.rel { display: flex; flex-direction: column; gap: 10px; padding: 22px; text-decoration: none; }
.rel .rel-cat { font-family: var(--font-mono); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase; color: var(--text-3); }
.rel h3 { font-size: 1.18rem; }
.rel p { color: var(--text-2); font-size: .9rem; line-height: 1.55; flex: 1; }
.rel .go { font-family: var(--font-mono); font-size: .76rem; color: var(--cyan); display: inline-flex; gap: .5em; align-items: center; }
.rel:hover .go { gap: .8em; }
