  /* ===== Catholic Word Quest — SCOPED STYLES (everything cwq-*) ===== */
 :root{
  --cwq-bg:#f6f1e7; --cwq-ink:#3c2f2f; --cwq-stone:#e3d9cd;
  --cwq-lead:#2a2a2a; --cwq-lead-hi:#6f6f6f;
  --cwq-success:#1d7a3a; --cwq-fail:#8b1d1d;
}

/* Containment & base */
*, *::before, *::after { box-sizing: border-box; }
.gamebody{
  margin:0; background:var(--cwq-bg); color:var(--cwq-ink);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  display:flex; flex-direction:column; align-items:center;
}

/* Wrapper: fits inside any parent, capped at 978px */
.cwq-wrap{
  max-width:978px; width:100%; margin:0 auto;
  padding:8px 16px 32px; overflow-x:hidden;
}

/* Grid layout */
.cwq-board{
  display:grid; gap:18px; grid-template-columns: 1fr;
  width:100%; min-width:0;
}
/* Desktop: enforce 65% / 35% split */
@media (min-width: 900px){
  .cwq-board{
    grid-template-columns: minmax(0,65%) minmax(0,35%);
    align-items:start;
  }
}

/* Cards */
.cwq-card{
  background:#fff; border:1px solid var(--cwq-stone);
  border-radius:12px; box-shadow:0 6px 22px rgba(0,0,0,.06);
  min-width:0; overflow:hidden;
}
.cwq-side{ padding:16px; }
.cwq-stage{ padding:12px; }

/* Mobile mount is visible only under 600px */
.cwq-stage-mount{ display:none; }
@media (max-width: 599px){
  .cwq-stage-mount{ display:block; padding:20px 0; }
}

/* Word display */
#cwq-wordDisplay{
  font-size: clamp(24px, 4vw, 40px);
  letter-spacing:.25em; text-align:center; background:white;
  border:1px solid var(--cwq-stone); border-radius:12px; padding:16px;
  min-height:64px; display:flex; align-items:center; justify-content:center;
  user-select:none; margin-bottom:10px; box-shadow: 0 4px 18px rgba(0,0,0,.05);
}

/* Keyboard */
.cwq-keyboard{ display:grid; gap:8px; grid-template-columns: repeat(9, 1fr); }
.cwq-key{
  padding:10px 0; font-size:18px; border-radius:8px;
  border:1px solid var(--cwq-ink); background:white; cursor:pointer;
}
.cwq-key:disabled{ background:#ddd; color:#777; border-color:#ccc; cursor:not-allowed; }

/* Message + pills */
#cwq-message{ min-height:42px; text-align:center; margin-top:6px; }
.cwq-win{ color:var(--cwq-success); font-weight:700; }
.cwq-lose{ color:var(--cwq-fail); font-weight:700; }
.cwq-row{ display:flex; gap:10px; align-items:center; justify-content:center; flex-wrap:wrap; margin:8px 0; }
.cwq-pill{ background:#fff; border:1px solid var(--cwq-stone); border-radius:999px; padding:6px 10px; font-size:12px; }

/* Stats & share */
.cwq-statgrid{ display:grid; grid-template-columns: repeat(4, 1fr); gap:10px; margin-top:8px; }
.cwq-stat{ text-align:center; background:#fff; border:1px solid var(--cwq-stone); border-radius:10px; padding:12px; }
.cwq-stat .cwq-num{ font-size:22px; font-weight:800; }
.cwq-stat .cwq-lbl{ font-size:12px; opacity:.7; }
.cwq-sharebox{ display:flex; gap:8px; justify-content:center; margin-top:8px; }
.cwq-sharetext{ width:100%; max-width:560px; min-height:70px; padding:10px; border-radius:10px; border:1px solid var(--cwq-stone); }
.cwq-share-row{ display:flex; gap:8px; justify-content:center; flex-wrap:wrap; margin-top:8px; }
.cwq-btn{ padding:8px 12px; border-radius:8px; border:1px solid #d8cfc4; background:white; cursor:pointer; font-size:14px; }
.cwq-btn.cwq-primary{ background:var(--cwq-ink); color:#fff; border-color:var(--cwq-ink); }
.cwq-btn:disabled{ opacity:.5; cursor:not-allowed; }

/* Stage image/SVG containment */
.cwq-wrap img, .cwq-wrap svg, .cwq-wrap canvas{ max-width:100%; height:auto; }
.cwq-svgbox{
  width:100%; aspect-ratio:1/1; position:relative; overflow:hidden;
  border-radius:50%; border:6px solid var(--cwq-stone);
  box-shadow:inset 0 0 0 2px #cfc6b8, 0 8px 20px rgba(0,0,0,.08);
}
.cwq-svgbox img{ width:100%; height:100%; object-fit:cover; object-position:center; display:block; border-radius:50%; }
.cwq-svgbox svg{ width:100%; height:100%; display:block; position:absolute; inset:0; }

/* Overlay (if used) */
.cwq-overlay{
  position:absolute; inset:0; background:rgba(0,0,0,.68); color:#fff;
  display:none; justify-content:center; align-items:center; text-align:center; padding:16px;
  border-radius:50%; z-index:3;
}
.cwq-overlay .cwq-inner{ font-size: clamp(16px, 2.4vw, 22px); line-height:1.3; }

/* Wedge visuals (if using the SVG state effects) */
.cwq-piece { transition: transform 0.3s ease; transform-origin: 200px 200px; }
.cwq-piece.cwq-grayed { transform: scale(0.98); filter: url(#cwq-desat); }
.cwq-piece .cwq-gray { fill: #6b6b6b; opacity: 0; mix-blend-mode: multiply; transition: opacity .25s ease; }
.cwq-piece.cwq-grayed .cwq-gray { opacity: .92; }
@keyframes cwq-shimmer { 0% { filter: brightness(1) drop-shadow(0 0 0px gold);} 50% { filter: brightness(1.3) drop-shadow(0 0 6px gold);} 100% { filter: brightness(1) drop-shadow(0 0 0px gold);} }
.cwq-piece.cwq-win-shimmer { animation: cwq-shimmer 1s ease-in-out 2; }

/* Optional: header text (if you include it) */
.cwq-header{ padding:18px 16px 8px; text-align:center;}
.cwq-header h1{ margin:0 0 6px; font-weight:800; letter-spacing:.5px;}
.cwq-subtitle{opacity:.8; margin-bottom:6px;}
.cwq-instructions{
  max-width:1000px; margin:0 auto 10px; padding:10px 12px;
  background:#fff; border:1px solid var(--cwq-stone); border-radius:10px; font-size:14px;
}

/* Debug (optional) */
details.cwq-debug{ max-width:978px; margin:16px auto; font-size:12px; color:#333; }
details.cwq-debug summary{ cursor:pointer; }
pre.cwq-debuglog{ background:#fff; border:1px solid var(--cwq-stone); border-radius:8px; padding:8px; white-space:pre-wrap; }
