@charset "utf-8";

/* --------------------------------------------------------
BOARD - LIST
----------------------------------------------------------*/
.boardListWrap {position:relative;}

/* galleryTadi list */
[data-board="gallery_default"] {display:grid;grid-template-columns:repeat(auto-fill, minmax(325px, auto)); grid-gap:20px; scrollbar-width:none;-webkit-box-pack:center;}
[data-board="gallery_default"] .cardBox {display:flex; flex-direction:column; position:relative; overflow:hidden; gap:10px; border-radius:8px; background:var(--board-white); transition:all 0.3s ease; box-shadow:0 0px 0px 1px var(--board-gray-300); opacity:0; transform:translateY(20px); animation:fadeInUp 0.6s ease forwards;}
[data-board="gallery_default"] .cardBox.active,
[data-board="gallery_default"] .cardBox:hover {z-index:1; transform:translateY(-8px) scale(1.02); box-shadow:0 0px 0px 1px var(--color-prime);}
[data-board="gallery_default"] .cardBox .checkBox {position:absolute; z-index:1; top:20px; right:20px; opacity:0; transform:scale(0.8); }
[data-board="gallery_default"] .cardBox:hover .checkBox {opacity:1; transform:scale(1);}
[data-board="gallery_default"] .cardBox .thumb {display:flex; justify-content:center; position:relative; overflow:hidden; border-radius:8px;}
[data-board="gallery_default"] .cardBox .thumb .labelBox {position:absolute; z-index:1; top:6px; left:6px;}
[data-board="gallery_default"] .cardBox:hover .thumb .labelBox {transform:translateY(0); opacity:1;}
[data-board="gallery_default"] .cardBox .thumb .picLabelBox {position:absolute; z-index:1; top:unset; bottom:6px; left:6px;}
[data-board="gallery_default"] .cardBox .thumb img {width:100%; transition:transform 0.4s ease;}
[data-board="gallery_default"] .cardBox:hover .thumb img {transform:scale(1.05);}
[data-board="gallery_default"] .cardBox .thumb .youtube_ico {display:flex; justify-content:center; align-items:center; position:absolute; top:0; width:100%; height:100%; background:rgba(0, 0, 0, 0.3); opacity:0; transition:all 0.3s ease;}
[data-board="gallery_default"] .cardBox:hover .thumb .youtube_ico {opacity:1;}
[data-board="gallery_default"] .cardBox .thumb .youtube_ico img {width:50px; transform:scale(0.8); transition:transform 0.2s ease;}
[data-board="gallery_default"] .cardBox:hover .thumb .youtube_ico img {transform:scale(1);}
[data-board="gallery_default"] .cardBox .cardBoxContent {display:flex; flex-direction:column; justify-content:space-between; gap:20px; height:40%;}
[data-board="gallery_default"] .cardBox .cardBoxContent .titleBox {display:flex; flex-direction:column; gap:10px;}
[data-board="gallery_default"] .cardBox .cardBoxContent .titleBox .title {display:block; color:var(--board-gray-900); font-size:16px; font-weight:600; line-height:1.2; display:-webkit-box; overflow:hidden; text-overflow:ellipsis; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
[data-board="gallery_default"] .cardBox .cardBoxContent .titleBox .title a {font-size:16px;}
[data-board="gallery_default"] .cardBox:hover .cardBoxContent .titleBox .title {color:var(--color-prime);}
[data-board="gallery_default"] .cardBox .cardBoxContent .titleBox .desc {display:block; color:var(--board-gray-500); font-size:13px; font-weight:400; text-align:left; line-height:1.4; opacity:0.8; display:-webkit-box; overflow:hidden; text-overflow:ellipsis; -webkit-line-clamp:2; -webkit-box-orient:vertical;}
[data-board="gallery_default"] .cardBox:hover .cardBoxContent .titleBox .desc {opacity:1;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox {justify-content:space-between; align-items:center; display:flex;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .user {display:flex; justify-content:center; align-items:center; width:30px; height:30px; background:var(--board-gray-300); border-radius:50%; overflow:hidden; transition:transform 0.2s ease;}
[data-board="gallery_default"] .cardBox:hover .cardBoxContent .infoBox .user {transform:scale(1.1);}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .user img {width:100%; height:100%; border-radius:50%; object-fit:cover;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .info {gap:10px; display:flex; align-items:center;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .info dl {width:auto; border:0; margin:0; display:flex; align-items:center; gap:4px;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .info dl dt {color:var(--board-gray-500); font-size:14px;}
[data-board="gallery_default"] .cardBox .cardBoxContent .infoBox .info dl dd {color:var(--board-gray-600); font-size:13px; margin:0;}

.admin-topic-info {display:flex; align-items:center; padding:var(--spacing-sm); border:1px solid var(--border-color); border-radius:var(--ui-radius-m); background:var(--bg-light); margin-bottom:20px;}
.admin-topic-info .topic-wrap {display:flex; align-items:center; gap:10px;}
.admin-topic-info .topic-wrap i {}
.admin-topic-info .topic-wrap .txt {padding:6px 10px; border-radius:6px; background:var(--color-prime);}

/* 애니메이션 키프레임 */
@keyframes fadeInUp {
  0% {opacity:0; transform:translateY(20px);}
  100% {opacity:1; transform:translateY(0);}
}

/* 로딩 애니메이션 */
[data-board="gallery_default"].loading .cardBox {animation:pulse 1.5s ease-in-out infinite;}
@keyframes pulse {
  0%, 100% {opacity:0.4;}
  50% {opacity:0.8;}
}

/* 반응형 애니메이션 조정 */
@media (max-width: 768px) {
  [data-board="gallery_default"] .cardBox:hover {transform:translateY(-4px) scale(1.01);}
  [data-board="gallery_default"] .cardBox:hover .thumb img {transform:scale(1.02);}
}

@media (prefers-reduced-motion: reduce) {
  [data-board="gallery_default"] .cardBox {animation:none; opacity:1; transform:none;}
  [data-board="gallery_default"] .cardBox:hover {transform:none; transition:box-shadow 0.2s ease;}
}

/* 그림 그리기 게시판 스타일 */
.boardWriteWrap .boardWrite .boardWriteBody .writeBox .title-area {display:flex; gap:10px;}
.boardWriteWrap .boardWrite .boardWriteBody .writeBox .title-area input {font-size:16px; font-weight:600;}

/* 드로잉 에디터 컨테이너 - 그리드 레이아웃 */
.drawing-editor-container {display:grid; grid-template-columns:1fr 280px; gap:16px; margin-bottom:20px; padding:20px; background:var(--board-white); border:1px solid var(--board-gray-200); border-radius:var(--board-radius-lg);}

/* 왼쪽: 에디터 섹션 (캔버스) */
.editor-section {display:flex; flex-direction:column; gap:20px;}
.editor-section .canvas-wrapper {display:flex; justify-content:center;}

/* 오른쪽: 툴바 섹션 */
.toolbar-section {display:flex; flex-direction:column; gap:20px; padding:20px; background:var(--board-gray-50); border:1px solid var(--board-gray-200); border-radius:var(--board-radius-sm);}

/* 툴 그룹 */
.tool-group {display:flex; flex-direction:column; gap:10px;}
.tool-group-title {margin:0; font-size:13px; font-weight:600; color:var(--board-gray-800);}

/* AI 생성기 섹션 */
.ai-generator-section {margin-bottom:20px;}
.ai-generator-section .tool-group-title {display:flex; align-items:center; gap:6px; margin-bottom:12px; font-size:14px; font-weight:600; color:var(--board-gray-800);}
.ai-generator-section .tool-group-title i {font-size:16px; color:var(--color-prime);}
.ai-generator-wrapper {display:flex; flex-direction:column; gap:10px;}
.btn-generate-ai {display:flex; align-items:center; justify-content:center; width:100%; padding:10px 18px; border:none; border-radius:var(--board-radius-sm); background:var(--color-prime); color:var(--board-white); font-size:14px; font-weight:600; cursor:pointer; gap:6px;  white-space:nowrap;}
.btn-generate-ai:hover {opacity:0.9; transform:translateY(-1px);}
.btn-generate-ai:active {transform:translateY(0);}
.btn-generate-ai:disabled {opacity:0.6; cursor:not-allowed; transform:none;}
.btn-generate-ai i {font-size:18px;}

/* 도구 버튼 그룹 - 2x2 그리드 */
.tool-buttons {display:grid; grid-template-columns:repeat(2, 1fr); gap:8px;}

/* 도구 버튼 */
.tool-btn {display:flex; align-items:center; gap:8px; padding:10px 12px; background:var(--board-white); border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); color:var(--board-gray-700); font-size:13px; cursor:pointer; }
.tool-btn:hover {background:var(--board-gray-100); border-color:var(--color-prime); color:var(--color-prime);}
.tool-btn.active {background:var(--color-prime); border-color:var(--color-prime); color:var(--board-white);}
.tool-btn i {width:18px; height:18px; font-size:18px; flex-shrink:0;}
.tool-btn span {flex:1; text-align:left;}

/* 편집 컨트롤 - 2x2 그리드 */
.editor-controls {display:grid; grid-template-columns:repeat(3, 1fr); gap:8px;}
.control-btn {display:flex; align-items:center; justify-content: center; gap:8px; width:100%; padding:10px 12px; background:var(--board-white); border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); color:var(--board-gray-700); font-size:13px; cursor:pointer; }
.control-btn:hover:not(:disabled) {background:var(--board-gray-100); border-color:var(--color-prime); color:var(--color-prime);}
.control-btn.active {background:var(--color-prime); border-color:var(--color-prime); color:var(--board-white);}
.control-btn:disabled {opacity:0.5; cursor:not-allowed;}
.control-btn i {width:18px; height:18px; font-size:18px; flex-shrink:0;}
.control-btn span {flex:1; text-align:left;}

/* 브러시 크기 */
.size-slider {width:180px; height:8px; margin:0 8px; border-radius:4px; outline:none; background:var(--board-gray-300); -webkit-appearance:none;}
.size-slider::-webkit-slider-thumb {width:22px; height:22px; border:3px solid var(--board-white-only); border-radius:50%; background:var(--board-gray-800); box-shadow:0 3px 6px rgba(0,0,0,0.3); cursor:pointer; -webkit-appearance:none;}
.size-slider::-moz-range-thumb {width:22px; height:22px; border:3px solid var(--board-white-only); border-radius:50%; background:var(--board-gray-800); box-shadow:0 3px 6px rgba(0,0,0,0.3); cursor:pointer;}
.size-slider::-webkit-slider-track {height:8px; border-radius:4px; background:var(--board-gray-800);}
.size-slider::-moz-range-track {height:8px; border:none; border-radius:4px; background:var(--board-gray-800);}
#size-display {min-width:30px; font-size:12px; font-weight:600;}

/* 색상 컨트롤 */
.color-controls {display:flex; flex-direction:column; gap:10px;}
#color-picker {width:100%; height:40px; border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); cursor:pointer;}

/* 색상 팔레트 */
.color-palette {display:grid; grid-template-columns:repeat(8, 1fr); gap:8px; margin-top:8px;}
.color-chip {width:100%; aspect-ratio:1; outline:1px solid var(--board-gray-300); outline-offset:2px; border-radius:50%; cursor:pointer; }
.color-chip:hover {border-color:var(--board-gray-600); transform:scale(1.1);}
.color-chip.active {outline: 2px solid var(--color-prime);}

/* 캔버스 */
#drawing-canvas {display:block; background:var(--board-white-only); border-radius: var(--board-radius-sm); box-shadow:inset 0px 0px 0px 1px rgba(0, 0, 0, 0.1); cursor:crosshair;}
.canvas-info {margin-top:8px; text-align:center;}
.canvas-info small {color:var(--board-gray-600); font-size:12px;}
/* 도구별 커서 */
.canvas-wrapper[data-tool="pen"] #drawing-canvas {cursor:none;}
.canvas-wrapper[data-tool="eraser"] #drawing-canvas {cursor:none;}
.canvas-wrapper[data-tool="fill"] #drawing-canvas {cursor:crosshair;}
.canvas-wrapper[data-tool="eyedropper"] #drawing-canvas {cursor:crosshair;}

/* 반응형 디자인 */
@media (max-width:1024px) {
  .drawing-editor-container {grid-template-columns:1fr 240px; gap:20px;}
}
@media (max-width:768px) {
  .drawing-editor-container {grid-template-columns:1fr; gap:16px;}
  #drawing-canvas {width:100%; max-width:100%;}
  .color-palette {flex-wrap:wrap; justify-content:center;}
  .size-slider {width:150px;}
}
@media (max-width:480px) {
  .size-slider {width:120px;}
}

/* 브러시 커서 */
.brush-cursor {position:fixed; z-index:1000; border:2px solid var(--board-gray-800); border-radius:50%; background:var(--board-overlay-200); pointer-events:none; transform:translate(-50%, -50%); transition:width 0.1s ease, height 0.1s ease;}

/* 로딩 상태 */
.drawing-container.loading {opacity:0.7; pointer-events:none;}
.drawing-container.loading::after {content:"로딩 중..."; position:absolute; top:50%; left:50%; padding:8px 16px; border-radius:var(--board-radius-sm); background:rgba(0, 0, 0, 0.8); color:white; font-size:14px; transform:translate(-50%, -50%);}
/* 그림 플레이어 스타일 */
.drawing-player {margin:24px 0;}
.player-controls {display:flex; flex-wrap:wrap; justify-content:space-between; align-items:center; margin-top:8px; padding:16px; border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); background:var(--board-gray-50); gap:16px;}
.control-group {display:flex; align-items:center; gap:8px;}
.speed-control {display:flex; align-items:center; gap:8px;}
.speed-control label {margin:0; font-size:13px;}
.speed-control select {padding:4px 8px; border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); background:white;}
.progress-info {display:flex; align-items:center; color:var(--board-gray-900); font-size:13px; gap:4px;}
.progress-bar {margin:16px 0;}
.progress-track {position:relative; height:8px; border-radius:4px; background:var(--board-gray-300); cursor:pointer;}
.progress-fill {width:0%; height:100%; border-radius:4px; background:var(--color-prime); transition:width 0.1s ease;}
.progress-thumb {position:absolute; top:50%; left:0%; width:16px; height:16px; border:2px solid white; border-radius:50%; background:var(--color-prime); cursor:pointer; transform:translate(-50%, -50%);}
.player-container .canvas-wrapper {position:relative; text-align:center;}
#player-canvas {display:block; width:100%; max-width:100%; height:auto; margin:0 auto; border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); background:white;}
.canvas-overlay {display:flex; justify-content:center; align-items:center; position:absolute; top:0; left:0; right:0; bottom:0; border-radius:var(--board-radius-sm); background:rgba(0, 0, 0, 0.7); color:white;}
.play-overlay {text-align:center;}
.play-overlay i {margin-bottom:8px; opacity:0.9; font-size:48px;}
.play-overlay p {margin:0; font-size:16px;}
.error-overlay {color:var(--board-danger); text-align:center;}
.error-overlay i {margin-bottom:8px; font-size:48px;}
.no-drawing {padding:24px; color:var(--board-gray-600); text-align:center;}

/* 주제어 관련 스타일 */
.topic-area {display:flex; align-items:center; flex-wrap:wrap; padding:16px; border:1px solid var(--board-gray-300); border-radius:var(--board-radius-sm); background:var(--board-gray-50); gap:8px;}
.topic-area label {margin:0; font-size:14px; font-weight:500;}
.topic-word {padding:10px 20px; border-radius:var(--board-radius-sm); background:var(--color-prime) !important; color:var(--board-white-only); font-size:20px; font-weight:600;}
.topic-area .ai-btn {margin-left:auto; background:linear-gradient(135deg, #667eea 0%, #764ba2 100%); color:#ffffff; border:none; transition:all 0.3s ease;}
.topic-area .ai-btn:hover {background:linear-gradient(135deg, #764ba2 0%, #667eea 100%); transform:translateY(-2px); box-shadow:0 4px 12px rgba(102, 126, 234, 0.4);}
.topic-area .ai-btn i {font-size:16px; margin-right:4px;}
.topic-area .ai-btn:disabled {opacity:0.6; cursor:not-allowed; transform:none;}

/* AI 상태 표시 */
.ai-status {display:flex; align-items:center; gap:8px; padding:8px 12px; border-radius:var(--board-radius-sm); background:#e3f2fd; color:#1976d2; font-size:13px; animation:fadeIn 0.3s ease;}
@keyframes fadeIn {
  from {opacity:0; transform:translateY(-10px);}
  to {opacity:1; transform:translateY(0);}
}
.loading-spinner {display:inline-block; width:14px; height:14px; border:2px solid rgba(25, 118, 210, 0.2); border-top-color:#1976d2; border-radius:50%; animation:spin 0.8s linear infinite;}

/* 정답 뱃지 */
.correct-badge {display:inline-flex; align-items:center; margin-left:8px !important; padding:4px 8px !important; border-radius:12px !important; background:var(--board-mint) !important; color:var(--board-white-only) !important; font-size:12px !important; font-weight:600 !important; gap:4px; animation:correctBadge 0.5s ease;}
.correct-badge i {font-size:14px;}
[data-board="uxc_list"] .iconBox.correct-badge {display:inline-flex; justify-content:center; align-items:center; width:auto; height:auto; min-width:auto; margin-left:4px; padding:2px 6px; border-radius:10px; background:var(--board-mint); color:var(--board-white-only); font-size:10px; font-weight:600; gap:2px; animation:correctBadge 0.5s ease;}
[data-board="uxc_list"] .iconBox.correct-badge i {margin:0; font-size:14px;}
[data-board="uxc_list"] .cardBox:hover .iconBox.correct-badge {transform:scale(1.1);}

/* 폭죽 효과 */
.fireworks-container {position:fixed; z-index:9999; top:0; left:0; width:100%; height:100%; overflow:hidden; pointer-events:none;}
.firework {position:absolute; width:8px; height:8px; border-radius:50%; animation:firework 2s ease-out forwards;}
.firework.color1 {background:var(--board-danger);}
.firework.color2 {background:var(--board-lightblue);}
.firework.color3 {background:var(--board-blue);}
.firework.color4 {background:var(--board-green);}
.firework.color5 {background:var(--board-yellow);}
.firework.color6 {background:var(--board-purple);}
.firework.color7 {background:var(--board-mint);}
.firework.color8 {background:var(--board-orange);}
.celebration-text {position:fixed; z-index:10000; top:30%; left:50%; color:var(--board-danger); font-size:48px; font-weight:bold; text-shadow:2px 2px 4px rgba(0,0,0,0.3); transform:translate(-50%, -50%); pointer-events:none; animation:celebrationBounce 2s ease-out forwards;}

/* 애니메이션 */
@keyframes spin {to {transform:rotate(360deg);}}
@keyframes correctBadge {
  0% {opacity:0; transform:scale(0.8);}
  50% {transform:scale(1.1);}
  100% {opacity:1; transform:scale(1);}
}
@keyframes firework {
  0% {opacity:1; transform:scale(0) translate(0, 0);}
  20% {opacity:1; transform:scale(1.5) translate(var(--dx), var(--dy));}
  100% {opacity:0; transform:scale(0) translate(var(--dx), var(--dy));}
}
@keyframes celebrationBounce {
  0% {opacity:0; transform:translate(-50%, -50%) scale(0) rotate(-10deg);}
  30% {opacity:1; transform:translate(-50%, -50%) scale(1.2) rotate(5deg);}
  60% {transform:translate(-50%, -50%) scale(0.9) rotate(-2deg);}
  80% {transform:translate(-50%, -50%) scale(1.05) rotate(1deg);}
  100% {opacity:0; transform:translate(-50%, -50%) scale(1) rotate(0deg);}
}

/* 반응형 플레이어 */
@media (max-width:768px) {
  .player-controls {justify-content:center; flex-direction:column; gap:8px;}
  .control-group {flex-wrap:wrap; justify-content:center;}
  #player-canvas {width:100%; max-width:100%;}
  .play-overlay i {font-size:36px;}
  .play-overlay p {font-size:14px;}
}

/* 옵션 */
.settingForm {display:flex; align-items:center; justify-content:space-between;}