/* 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); }

/* ---- 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); }
