/* Page-specific layout. */

/* ---- Hero (landing) ---- */
.hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-8);
  align-items: center;
  max-width: var(--content-wide);
  margin: 0 auto;
  padding: var(--space-9) var(--space-6);
}
.hero-inner { max-width: 38rem; }
.hero-actions {
  display: flex; gap: var(--space-3); flex-wrap: wrap;
  margin-top: var(--space-6);
}
.hero-art {
  display: grid; place-items: center;
  aspect-ratio: 1 / 1;
  background: linear-gradient(135deg, var(--surface-raised), var(--surface-sunken));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3);
  padding: var(--space-6);
  box-shadow: var(--shadow-3);
}

/* Decorative friendship-star block — pure CSS, hint of what's inside */
.block { width: 80%; aspect-ratio: 1/1; position: relative; border-radius: var(--radius-2); overflow: hidden;
  background:
    conic-gradient(from 45deg at 50% 50%,
      var(--color-rose) 0deg 45deg,
      var(--color-warm) 45deg 90deg,
      var(--color-deep-rose) 90deg 135deg,
      var(--color-warm) 135deg 180deg,
      var(--color-rose) 180deg 225deg,
      var(--color-warm) 225deg 270deg,
      var(--color-deep-rose) 270deg 315deg,
      var(--color-warm) 315deg 360deg);
  box-shadow: inset 0 0 0 8px var(--color-warm), var(--shadow-2);
}
.block::after {
  content: ''; position: absolute; inset: 28%;
  background: var(--color-sage);
  border-radius: var(--radius-1);
  transform: rotate(45deg);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
}

@media (max-width: 900px) {
  .hero { grid-template-columns: 1fr; padding: var(--space-7) var(--space-4); gap: var(--space-6); }
  .hero-art { max-width: 22rem; justify-self: center; }
}

/* ---- Features strip ---- */
.features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
  gap: var(--space-5);
  max-width: var(--content-wide);
  margin: 0 auto var(--space-9);
  padding: 0 var(--space-6);
}
.feature {
  background: var(--surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3);
  padding: var(--space-6);
  box-shadow: var(--shadow-1);
}
.feature h2 { font-size: var(--fs-500); }
.feature p  { color: var(--ink-secondary); margin: 0; }

/* ---- Generic prose ---- */
.prose {
  max-width: var(--content-narrow);
  margin: var(--space-8) auto;
  padding: 0 var(--space-5);
}
.prose h1 { font-size: var(--fs-800); margin-bottom: var(--space-5); }

/* ---- Designer shell placeholder ---- */
.designer-shell {
  max-width: var(--content-wide);
  margin: var(--space-6) auto;
  padding: 0 var(--space-5);
  min-height: 70vh;
}

.dashboard-actions { display: flex; gap: var(--space-3); margin: var(--space-5) 0; }

/* ---- Studio (dashboard) ---- */
.studio { max-width: var(--content-wide); margin: var(--space-7) auto; padding: 0 var(--space-6); }
.studio-head { margin-bottom: var(--space-7); }
.studio-head .display { margin-bottom: var(--space-3); font-size: clamp(2.2rem, 3.5vw + 1rem, 3.4rem); }
.studio-actions { display: flex; gap: var(--space-3); margin-top: var(--space-5); }
.studio-section { margin-bottom: var(--space-8); }
.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-divider);
  padding-bottom: var(--space-3);
}
.section-head h2 { margin: 0; font-size: var(--fs-600); }
.empty {
  background: var(--surface-raised);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-3);
  padding: var(--space-6);
  text-align: center;
  color: var(--ink-secondary);
}
.card-grid {
  list-style: none; margin: 0; padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15rem, 1fr));
  gap: var(--space-5);
}
.card-grid-sm { grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr)); gap: var(--space-4); }
.card-thumb {
  aspect-ratio: 1 / 1;
  background: var(--surface-sunken);
  border-bottom: 1px solid var(--color-border);
  display: grid; place-items: center;
  overflow: hidden;
}
.card-thumb img { width: 100%; height: 100%; object-fit: cover; }
.card-thumb-placeholder {
  width: 100%; height: 100%;
  display: grid; place-items: center;
  font-family: var(--font-serif);
  font-size: var(--fs-800);
  color: var(--color-deep-rose);
  background: linear-gradient(135deg, var(--surface-raised), var(--surface-sunken));
}
.card-thumb-placeholder.pattern { font-size: var(--fs-500); font-weight: 600; }
.project-card, .pattern-card {
  padding: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: transform var(--dur-2) var(--easing), box-shadow var(--dur-2) var(--easing);
}
.project-card:hover, .pattern-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-2);
}
.card-body { padding: var(--space-4) var(--space-5); flex: 1; }
.card-title { font-size: var(--fs-500); margin: 0 0 var(--space-2); }
.card-meta { margin: 0; font-size: var(--fs-300); }
.card-actions {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-divider);
  display: flex; gap: var(--space-3);
}
.card-actions .btn { padding: var(--space-2) var(--space-4); font-size: var(--fs-300); }

/* Solid red for the final confirm. */
.btn-danger {
  background: var(--color-danger);
  color: var(--ink-on-rose);
  border: 1px solid var(--color-danger);
}
.btn-danger:hover { background: color-mix(in srgb, var(--color-danger) 88%, black); }
.btn-danger:disabled { opacity: 0.55; cursor: not-allowed; }

/* Card fade-out for delete (paired with JS .is-removing toggle). */
.pattern-card, .project-card { transition: opacity 220ms ease, transform 220ms ease; }
.pattern-card.is-removing, .project-card.is-removing {
  opacity: 0;
  transform: scale(0.96);
  pointer-events: none;
}
/* Brief opacity dip while a duplicate-and-edit round-trip is in flight. */
.pattern-card.is-busy {
  opacity: 0.55;
  pointer-events: none;
}

/* Right-clickable affordance — patterns surface a context menu, so the
 * native browser menu would be confusing. Suppress it visually with
 * context-menu cursor on hover and disable text selection. */
.pattern-card {
  user-select: none;
  -webkit-user-select: none;
}
.pattern-card:hover {
  cursor: context-menu;
}

/* ---- Floating context menu (used by dashboard-patterns.js) ---- */
.qc-ctx-menu {
  position: fixed;
  z-index: 950;
  min-width: 200px;
  background: var(--surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2);
  box-shadow: var(--shadow-3);
  padding: var(--space-1);
  animation: qcCtxFade 120ms ease;
}
@keyframes qcCtxFade {
  from { opacity: 0; transform: translateY(-2px); }
  to   { opacity: 1; transform: translateY(0); }
}
.qc-ctx-header {
  padding: var(--space-2) var(--space-3);
  font-size: var(--fs-300);
  color: var(--ink-muted);
  border-bottom: 1px solid var(--color-divider);
  margin-bottom: var(--space-1);
  white-space: nowrap;
  max-width: 22ch;
  overflow: hidden;
  text-overflow: ellipsis;
}
.qc-ctx-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: none;
  border: 0;
  font: inherit;
  text-align: left;
  color: var(--ink-primary);
  border-radius: var(--radius-1);
  cursor: pointer;
}
.qc-ctx-item:hover, .qc-ctx-item:focus {
  background: var(--surface-sunken);
  outline: none;
}
.qc-ctx-danger {
  color: var(--color-danger);
}
.qc-ctx-danger:hover, .qc-ctx-danger:focus {
  background: color-mix(in srgb, var(--color-danger) 12%, var(--surface-raised));
  color: var(--color-danger);
}

/* ---- Confirm dialog (used by dashboard-patterns.js) ---- */
.qc-confirm-overlay {
  position: fixed; inset: 0;
  background: rgba(46, 34, 24, 0.55);
  z-index: 1000;
  display: grid; place-items: center;
  padding: var(--space-5);
  animation: qcConfirmFade 180ms ease;
}
@keyframes qcConfirmFade { from { opacity: 0; } to { opacity: 1; } }

.qc-confirm-card {
  background: var(--surface-page);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3);
  box-shadow: var(--shadow-3);
  width: min(440px, 100%);
  overflow: hidden;
}
.qc-confirm-head {
  padding: var(--space-5) var(--space-6) 0;
}
.qc-confirm-eyebrow {
  margin: 0;
  font-size: var(--fs-300);
  text-transform: uppercase;
  letter-spacing: var(--letter-wide);
  color: var(--color-danger);
  font-weight: 700;
}
.qc-confirm-head h2 {
  margin: var(--space-2) 0 0;
  font-family: var(--font-serif);
  font-size: var(--fs-600);
}

.qc-confirm-preview {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-5) var(--space-6);
}
.qc-confirm-thumb {
  width: 88px; height: 88px;
  border-radius: var(--radius-2);
  background: var(--surface-sunken);
  overflow: hidden;
  display: grid; place-items: center;
  border: 1px solid var(--color-border);
}
.qc-confirm-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.qc-confirm-thumb-fallback {
  font-family: var(--font-serif);
  color: var(--color-deep-rose);
  font-size: var(--fs-600);
  font-weight: 600;
}
.qc-confirm-meta strong {
  display: block;
  font-size: var(--fs-500);
  margin-bottom: var(--space-1);
}
.qc-confirm-meta p {
  margin: 0;
  font-size: var(--fs-300);
  line-height: var(--lh-base);
}

.qc-confirm-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-6) var(--space-5);
  background: var(--surface-raised);
  border-top: 1px solid var(--color-divider);
}

/* ---- Account ---- */
.account-page { max-width: var(--content-narrow); margin: var(--space-7) auto; padding: 0 var(--space-5); }
.account-page h1 { font-size: var(--fs-800); margin-bottom: var(--space-5); }
.account-list {
  display: grid; gap: 0;
  background: var(--surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3);
  padding: var(--space-2) var(--space-5);
  margin: var(--space-5) 0;
}
.account-row {
  display: grid; grid-template-columns: 12rem 1fr;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-divider);
}
.account-row:last-child { border-bottom: 0; }
.account-row dt { color: var(--ink-secondary); font-weight: 600; margin: 0; }
.account-row dd { margin: 0; }
.account-section { margin: var(--space-7) 0; }
.account-section h2 { font-size: var(--fs-500); margin-bottom: var(--space-3); }
@media (max-width: 600px) {
  .account-row { grid-template-columns: 1fr; gap: var(--space-1); }
}

/* ---- Share viewer ---- */
.share-page { max-width: var(--content-base); margin: var(--space-7) auto; padding: 0 var(--space-5); text-align: center; }
.share-head { text-align: center; margin-bottom: var(--space-6); }
.share-canvas-wrap {
  display: grid; place-items: center;
  background: var(--surface-raised);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-3);
  padding: var(--space-5);
  box-shadow: var(--shadow-2);
}
.share-canvas-wrap canvas {
  max-width: 100%; height: auto;
  background: var(--color-cream);
  border-radius: var(--radius-2);
}

/* ---- Error pages ---- */
.error-page { text-align: center; margin-top: var(--space-9); }
.error-page .eyebrow { color: var(--color-rose); }
