.ccg-game{--ccg-p1:#ff4fa3;--ccg-p2:#8d5cf6;--ccg-p3:#69d2ff;max-width:1320px;margin:0 auto}
.ccg-shell{background:radial-gradient(circle at top right,rgba(255,255,255,.75),transparent 28%),linear-gradient(135deg,#f4e6ff 0%,#e9f7ff 50%,#fff3de 100%);border:2px solid #ffd8ec;border-radius:30px;padding:18px;box-shadow:0 12px 40px rgba(0,0,0,.07);height:calc(100vh - 32px);max-height:calc(100vh - 32px);display:flex;flex-direction:column;overflow:hidden}
.ccg-header{margin-bottom:12px;flex:0 0 auto}
.ccg-badge{display:inline-block;background:linear-gradient(135deg,var(--ccg-p1),var(--ccg-p2));color:#fff;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em}
.ccg-title{margin:14px 0 10px;font-size:32px;line-height:1.1}
.ccg-layout{display:grid;grid-template-columns:300px 1fr;gap:16px;flex:1;min-height:0;overflow:hidden}
.ccg-sidebar{display:flex;flex-direction:column;gap:14px;min-height:0;overflow:auto;padding-right:4px}
.ccg-panel{background:rgba(255,255,255,.78);border-radius:24px;padding:16px;box-shadow:0 8px 24px rgba(0,0,0,.04)}
.ccg-panel-title{font-weight:800;margin-bottom:12px;font-size:18px}
.ccg-tool-grid{display:grid;grid-template-columns:repeat(5,48px);gap:8px}.ccg-tool-grid-controls{grid-template-columns:repeat(5,48px)}
.ccg-tool-btn,.ccg-action-btn{border:none;background:#fff;padding:12px 14px;border-radius:14px;cursor:pointer;font-weight:800;box-shadow:0 6px 16px rgba(0,0,0,.06);display:flex;align-items:center;gap:10px;justify-content:flex-start}.ccg-icon-btn{width:48px;height:48px;padding:0;justify-content:center;align-items:center;border:1px solid #ef4d86}
.ccg-tool-btn.is-active{background:#fff5fa;color:#ef4d86;border:2px solid #ef4d86}
.ccg-icon{font-size:24px;line-height:1;display:inline-flex;min-width:20px;justify-content:center}
.ccg-palette{display:grid;grid-template-columns:repeat(auto-fit,minmax(var(--ccg-palette-size,42px),var(--ccg-palette-size,42px)));gap:10px}
.ccg-color{width:var(--ccg-palette-size,42px);height:var(--ccg-palette-size,42px);border-radius:10px;border:2px solid #e44c89;cursor:pointer;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.ccg-color.is-active{box-shadow:0 0 0 3px #111}
.ccg-help{margin:10px 0 0;font-size:14px;opacity:.72}
.ccg-brush-size-wrap{margin-top:14px}
.ccg-brush-size-wrap label{display:block;margin-bottom:8px;font-weight:700}
.ccg-stage{min-width:0;min-height:0;overflow:hidden}
.ccg-canvas-wrap{background:#fff;border-radius:28px;padding:18px;overflow:auto;height:100%;min-height:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05),0 8px 24px rgba(0,0,0,.04);--ccg-canvas-scaled-width:600px;--ccg-canvas-scaled-height:400px}
.ccg-canvas-wrap::after{content:"";display:block;width:var(--ccg-canvas-scaled-width);height:var(--ccg-canvas-scaled-height)}
.ccg-canvas{display:block;max-width:none;height:auto;image-rendering:auto;cursor:crosshair;touch-action:none;position:absolute;top:18px;left:18px}
.ccg-game.ccg-move-mode .ccg-canvas{cursor:grab}
.ccg-game.ccg-move-mode .ccg-canvas:active{cursor:grabbing}

.ccg-canvas-wrap{position:relative}
@media (max-width:980px){.ccg-shell{height:auto;max-height:none;min-height:calc(100vh - 24px)}.ccg-layout{grid-template-columns:1fr;overflow:visible}.ccg-sidebar{overflow:visible;padding-right:0}.ccg-stage{min-height:420px;overflow:visible}.ccg-tool-grid{grid-template-columns:repeat(4,56px)}.ccg-tool-grid-controls{grid-template-columns:repeat(5,48px)}}


.ccg-mobile-toolbar,.ccg-mobile-sheet,.ccg-mobile-sheet-backdrop{display:none}
.ccg-mobile-toggle{border:none;background:#fff}
.ccg-mobile-sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:100}
.ccg-mobile-sheet{z-index:2147483647;position:fixed;left:12px;right:12px;bottom:82px;background:#fff;border-radius:20px 20px 16px 16px;box-shadow:0 18px 40px rgba(0,0,0,.22);z-index:2147483647;max-height:55vh;overflow:auto}
.ccg-mobile-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eee}
.ccg-mobile-sheet-body{padding:14px 16px}
.ccg-mobile-close{border:none;background:#fff;font-size:18px;cursor:pointer}
.ccg-mobile-more-grid{grid-template-columns:repeat(5,48px)}
.ccg-mobile-brush-size{margin-top:14px}
.ccg-mobile-palette{grid-template-columns:repeat(auto-fit,minmax(var(--ccg-palette-size,42px),var(--ccg-palette-size,42px)))}

@media (max-width:980px){
  .ccg-shell{padding-bottom:86px}
  .ccg-header{margin-bottom:8px}
  .ccg-title{font-size:28px}
  .ccg-desktop-panel{display:none}
  .ccg-layout{grid-template-columns:1fr}
  .ccg-stage{min-height:0}
  .ccg-canvas-wrap{height:calc(100vh - 210px);min-height:340px}
  .ccg-mobile-toolbar{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;position:fixed;left:12px;right:12px;transform:none;bottom:calc(12px + env(safe-area-inset-bottom, 0px));z-index:2147483647;background:rgba(255,255,255,.96);padding:10px 12px;border-radius:18px;box-shadow:0 12px 30px rgba(0,0,0,.18);overflow:hidden;justify-content:stretch}
  .ccg-mobile-toolbar .ccg-icon-btn{width:100%;min-width:0;height:46px}
  .ccg-mobile-toolbar .ccg-icon{font-size:20px}
  .ccg-mobile-sheet.is-open{display:block}
  .ccg-mobile-sheet-open .ccg-mobile-sheet-backdrop{display:block}
}


.ccg-badge{display:none}
.ccg-header{margin-bottom:4px}
.ccg-title{margin:14px 0 10px;font-size:32px;line-height:1.1}
.ccg-audio-toggle{
  position:absolute;
  top:14px;
  right:14px;
  width:44px;
  height:44px;
  border:none;
  border-radius:999px;
  background:#ef4d86;
  color:#fff;
  font-size:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(0,0,0,.16);
  z-index:100;
}
.ccg-audio-toggle.is-muted{background:#666}
.ccg-shell{position:relative}
.ccg-chooser{
  height:100%;
  overflow:auto;
  background:#fff;
  border-radius:28px;
  padding:18px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.05),0 8px 24px rgba(0,0,0,.04);
}
.ccg-chooser-header{margin-bottom:14px}
.ccg-chooser-title{margin:0 0 6px;font-size:26px}
.ccg-chooser-text{margin:0;color:#666}
.ccg-chooser-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.ccg-chooser-card{border:none;background:#fff;border-radius:18px;box-shadow:0 6px 18px rgba(0,0,0,.08);padding:10px;cursor:pointer;text-align:left;display:block}
.ccg-chooser-thumb{display:block;border-radius:14px;overflow:hidden;background:#f6f6f6;aspect-ratio:1/1}
.ccg-chooser-thumb img{display:block;width:100%;height:100%;object-fit:cover}
.ccg-chooser-label{display:block;margin-top:8px;font-weight:700;color:#222}
.ccg-canvas-wrap.is-hidden{display:none!important}

@media (max-width:980px){
  .ccg-audio-toggle{top:10px;right:10px;width:40px;height:40px;font-size:18px}
  .ccg-chooser{height:calc(100vh - 230px);min-height:320px}
  .ccg-chooser-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:480px){.ccg-mobile-toolbar{grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;padding:8px 10px;overflow:hidden}.ccg-mobile-toolbar .ccg-icon-btn{height:42px}.ccg-mobile-toolbar .ccg-icon{font-size:18px}}


.ccg-audio-box{
  position:absolute;
  top:14px;
  right:14px;
  z-index:100;
  display:flex;
  align-items:center;
  gap:8px;
  background:rgba(255,255,255,.92);
  padding:8px 10px;
  border-radius:14px;
  box-shadow:0 8px 18px rgba(0,0,0,.16);
}
.ccg-audio-toggle{
  position:static;
  width:40px;
  height:40px;
  border:none;
  border-radius:999px;
  background:#ef4d86;
  color:#fff;
  font-size:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:none;
  z-index:auto;
}
.ccg-audio-toggle.is-muted{background:#666}
.ccg-audio-volume{width:92px}
@media (max-width:980px){
  .ccg-audio-box{top:10px;right:10px;padding:6px 8px}
  .ccg-audio-volume{width:72px}
}

.ccg-header-inner{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.ccg-back-gallery{
  border:none;
  background:#fff;
  color:#ef4d86;
  border:1px solid #ef4d86;
  border-radius:12px;
  padding:10px 14px;
  font-weight:700;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  line-height:1;
}
.ccg-back-gallery:hover{
  background:#fff5fa;
}
@media (max-width:980px){
  .ccg-back-gallery{
    padding:9px 12px;
    font-size:14px;
  }
}

.ccg-icon-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.ccg-icon-btn svg,
.ccg-audio-toggle svg,
.ccg-mobile-toggle svg,
.ccg-tool-btn svg,
.ccg-action-btn svg{
  width:22px;
  height:22px;
  display:block;
  flex:0 0 22px;
  pointer-events:none;
}
.ccg-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  line-height:1;
}

.ccg-icon-btn{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}
.ccg-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  height:100%;
  font-size:22px;
  line-height:1;
  text-align:center;
}
.ccg-icon-btn svg,
.ccg-audio-toggle svg,
.ccg-mobile-toggle svg,
.ccg-tool-btn svg,
.ccg-action-btn svg{
  display:none !important;
}
