.page-header .page-description {
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
/* AI Coloring Book Prompt Generator Styles */

.cb-generator-container {
  max-width: 1440px;
  margin: 40px auto;
  padding: 0 20px;
  position: relative;
  z-index: 1000;
  pointer-events: auto;
}

.cb-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  align-items: start;
  grid-auto-flow: row;
}

@media (max-width: 980px) {
  .cb-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 1199px) { .cb-sticky { position: static; top: auto; } }
@media (max-width: 1199px) {
  .cb-grid { display: block !important; grid-template-columns: none !important; }
  .cb-col-left, .cb-col-right { grid-column: 1 !important; }
  .cb-card { width: 100% !important; }
  .cb-generator-container { max-width: 100% !important; padding-left: 12px; padding-right: 12px; }
}
@media (min-width: 1200px) {
  .cb-grid {
    grid-template-columns: 1.35fr 0.65fr !important;
  }
}

.cb-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 14px;
  padding: 16px;
  box-shadow: none;
  position: relative;
  z-index: 1;
}

/* Explicit column placement */
.cb-col-left { grid-column: 1 !important; z-index: 50; }
.cb-col-right { grid-column: 2 / span 1 !important; z-index: 1; pointer-events: none; position: static; align-self: start; }
.cb-sticky { position: sticky; top: 90px; }
@media (min-width: 1200px) {
  .cb-right-top { grid-row: 1 !important; }
  .cb-right-bottom { grid-row: 2 !important; }
}
.cb-col-right .cb-output,
.cb-col-right .cb-actions,
.cb-col-right .cb-button,
.cb-col-right .cb-copy,
.cb-col-right .cb-preset,
.cb-col-right .cb-preset-btn,
.cb-col-right pre { pointer-events: auto; }

/* Ensure inputs stack above outputs no matter the DOM order */
.cb-grid > .cb-card { z-index: 40; }
.cb-grid > .cb-col-right { z-index: 1; }

/* Non-heading titles inside tool */
.cb-section-title {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--color-white, #fff);
  margin: 0 0 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding-bottom: 8px;
}
.cb-model-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--color-white, #fff);
  margin: 8px 0 10px;
  display: flex; align-items: center; gap: 8px;
}
.cb-subtitle {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-white, #fff);
  margin: 6px 0 8px;
}

.cb-row { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; margin-bottom: 15px; }
.cb-row-1 { display: grid; grid-template-columns: 1fr; gap: 15px; margin-bottom: 15px; }

@media (max-width: 768px) {
  .cb-row { grid-template-columns: 1fr; }
}

.cb-form-group label { display: block; font-size: 1.1rem; color: var(--color-white, #fff); margin-bottom: 8px; font-weight: 500; }
.cb-form-group input,
.cb-form-group select,
.cb-form-group textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: var(--color-white, #fff);
  font-size: 1.05rem;
  transition: all 0.3s ease;
}

.cb-form-group textarea { min-height: 100px; resize: vertical; }

.cb-form-group input::placeholder,
.cb-form-group textarea::placeholder { color: rgba(255, 255, 255, 0.5); }

.cb-form-group input:focus,
.cb-form-group select:focus,
.cb-form-group textarea:focus {
  border-color: var(--color-primary, #7c5cff);
  outline: none;
  box-shadow: 0 0 0 2px rgba(124, 92, 255, 0.3);
}

.cb-hint { font-size: 0.95rem; color: var(--color-midgrey, #aaa); margin-top: 6px; }

.cb-checkboxes { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 12px; }
@media (max-width: 600px) { .cb-checkboxes { grid-template-columns: 1fr; } }
@media (min-width: 1024px) { .cb-checkboxes { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.cb-checkboxes label { font-size: 1rem; color: var(--color-white, #fff); display: inline-flex; align-items: center; gap: 8px; cursor: pointer; justify-content: center; text-align: center; width: 100%; white-space: normal; overflow-wrap: break-word; word-break: normal; flex-wrap: wrap; line-height: 1.2; }
.cb-checkboxes input { accent-color: var(--color-primary, #7c5cff); }

/* Image-based category selectors */
.cb-categories { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px 16px; }
@media (min-width: 768px) { .cb-categories { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (min-width: 1200px) { .cb-categories { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
.cb-cat { display: grid !important; grid-template-columns: 1fr; grid-template-rows: auto auto auto; grid-auto-flow: row; justify-items: center; align-content: start; gap: 6px; cursor: pointer; text-align: center; user-select: none; width: 100%; }
.cb-cat-name, .cb-cat-desc { display: block !important; width: 100%; }
.cb-cat-name { margin-top: 4px; clear: both; }
.cb-cat-desc { margin-top: 2px; clear: both; }
.cb-cat input { position: absolute; opacity: 0; pointer-events: none; }
.cb-cat-img { width: 96px; height: 96px; border-radius: 9999px; overflow: hidden; border: 2px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.06); display: block !important; margin-inline: auto; float: none !important; }
@media (max-width: 480px) { .cb-cat-img { width: 84px; height: 84px; } }
.cb-cat-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cb-cat-name { font-size: 0.95rem; color: var(--color-white,#fff); line-height: 1.25; }
.cb-cat-desc { font-size: 0.85rem; color: var(--color-midgrey, #a9a9a9); line-height: 1.3; text-align: center; max-width: 14em; }
.cb-cat:hover .cb-cat-img { border-color: rgba(255,255,255,0.35); }
.cb-cat:has(input:checked) .cb-cat-img { border-color: var(--color-primary, #7c5cff); box-shadow: 0 0 0 3px rgba(124, 92, 255, 0.3); }
/* Fallback when :has not supported */
.cb-cat.is-checked .cb-cat-img { border-color: var(--color-primary, #7c5cff); box-shadow: 0 0 0 3px rgba(124, 92, 255, 0.3); }

 

/* Chip style for checkbox labels */
.cb-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.04);
  color: var(--color-white, #fff);
  padding: 8px 12px;
  border-radius: 8px;
  line-height: 1.2;
  justify-content: center;
  text-align: center;
  width: 100%;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: normal;
  flex-wrap: wrap;
}
.cb-chip:hover { background: rgba(255,255,255,0.08); }
.cb-chip input { transform: translateY(1px); margin-right: 6px; }
/* highlight selected categories with :has support */
.cb-checkboxes label:has(input:checked),
.cb-chip:has(input:checked) {
  background: rgba(124, 92, 255, 0.15);
  border-radius: 8px;
  padding: 6px 10px;
}
/* fallback when :has is not supported */
.cb-checkboxes label.is-checked,
.cb-chip.is-checked {
  background: rgba(124, 92, 255, 0.15);
  border-radius: 8px;
  padding: 6px 10px;
}

.cb-inline { display: flex; align-items: center; gap: 10px; margin-top: 8px; }
.cb-inline label { margin: 0; font-size: 1rem; color: var(--color-midgrey, #bbb); }

/* small description under sections */
.cb-desc { font-size: 0.95rem; color: var(--color-midgrey, #a9a9a9); margin-top: 6px; line-height: 1.5; }

/* right side action bar */
.cb-actions.right { display: flex; gap: 8px; justify-content: flex-end; margin-bottom: 10px; }

/* preview placeholder on right */
.cb-preview-placeholder { border: 2px dashed rgba(255,255,255,0.15); background: rgba(255,255,255,0.03); border-radius: 8px; padding: 16px; margin-bottom: 12px; text-align: center; }
.cb-preview-label { font-weight: 600; color: var(--color-white,#fff); }
.cb-preview-hint { font-size: 0.95rem; color: var(--color-midgrey,#aaa); margin-top: 4px; }

.cb-actions.small { justify-content: flex-end; }

.cb-button {
  cursor: pointer;
  border: 1px solid var(--color-primary, #7c5cff);
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.18), rgba(124, 92, 255, 0.05));
  color: var(--color-white, #fff);
  padding: 10px 14px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.25s ease;
}
@media (min-width: 1200px) {
  .cb-grid {
    grid-template-columns: 1fr 1fr;
  }
}
.cb-button:hover { transform: translateY(-1px); box-shadow: 0 5px 15px rgba(124, 92, 255, 0.4); }
.cb-button.secondary { border: 1px solid rgba(255, 255, 255, 0.1); background: rgba(255, 255, 255, 0.05); color: var(--color-white, #fff); }
.cb-button.secondary:hover { background: rgba(255, 255, 255, 0.1); }

.cb-output { background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.05); padding: 15px; border-radius: 10px; margin-top: 10px; max-height: 65vh; overflow: auto; }
.cb-output pre { margin: 0; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 1.15rem; color: var(--color-white, #fff); white-space: pre-wrap; word-break: break-word; }
.cb-output { position: relative; z-index: 1 !important; }

/* Defensive: ensure form areas accept pointer events */
.cb-form-section, .cb-form-group, .cb-form-group * {
  pointer-events: auto;
}

/* Ensure form controls sit above any accidental overlays */
.cb-form-group input,
.cb-form-group select,
.cb-form-group textarea,
.cb-checkboxes input,
.cb-checkboxes label {
  position: relative;
  z-index: 200;
}

.cb-preset { display: flex; gap: 10px; flex-wrap: wrap; }
.cb-preset-btn { cursor: pointer; border: 1px solid rgba(255,255,255,0.12); background: rgba(255,255,255,0.05); color: var(--color-white,#fff); padding: 8px 12px; border-radius: 8px; font-weight: 600; font-size: 0.95rem; }
.cb-preset-btn:hover { background: rgba(255,255,255,0.1); }

.cb-toast { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); background: var(--color-primary, #7c5cff); color: #fff; padding: 10px 16px; border-radius: 8px; font-weight: 500; display: none; z-index: 1000; box-shadow: 0 5px 20px rgba(0,0,0,0.2); }
.cb-toast.show { display: block; animation: cb-fade 3s ease forwards; }

@keyframes cb-fade { 0% { opacity: 0; transform: translate(-50%, 20px); } 10% { opacity: 1; transform: translate(-50%, 0); } 90% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, -20px); } }
