@charset "utf-8";



/* =========================
   0) BASE
========================= */
#bo_list{
  position: relative;
  overflow: visible; /* hidden → visible */
  max-width: 800px;
  margin: 0 auto;
  padding: 20px 0;
}

/* =========================
   1) CATEGORY
========================= */
#bo_cate{ margin: var(--spacing-lg) 0; }

#bo_cate h2{
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

#bo_cate ul{
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xs);
  list-style: none;
  padding: 0;
  margin: 0;
  justify-content: center;
}

#bo_cate li{ display: inline-block; }

#bo_cate a{
  display: block;
  padding: var(--spacing-xs) var(--spacing-md);
  border-radius: var(--container-border-radius);
  background: var(--primary-color);
  color: var(--btn-primary-bg);
  text-decoration: none;
  transition: var(--transition-fast);
}

#bo_cate a:hover{
  background: var(--btn-primary-text);
  color: var(--btn-primary-bg);
  border-color: var(--primary-color);
}

#bo_cate #bo_cate_on{
  background: var(--btn-primary-text);
  color: var(--btn-primary-bg);
  border-color: var(--primary-color);
}

/* =========================
   2) SEARCH
========================= */
#bo_sch{
  display: flex;
  justify-content: flex-end; /* 오른쪽 정렬 */
  border: 0;
  padding: 0;
  margin: 18px 0;
}

/* 폼 너비 */
#bo_sch form{
  width: 50%;
}

@media (max-width: 768px){
  #bo_sch{
    justify-content: stretch;
  }
  #bo_sch form{
    width: 100%;
  }
}

/* =========================
   3) HEADER
========================= */
.quote-header{
  text-align: center;
  margin-bottom: 40px;
}

.quote-title{
  font-size: 4rem;
  font-weight: bold;
  line-height: 1.2;
  margin: 0 0 var(--spacing-xs) 0;

  color: var(--title-font-color, rgba(255,255,255,0.85));
  white-space: pre-line;
  overflow: hidden;

  font-family: var(--title-font-family);
  font-style: italic;
}

.quote-subtitle{
  font-size: 1em;
  color: var(--text-muted);
  margin-top: 10px;
}

.quote-subtitle a{
  color: var(--accent-color);
  text-decoration: none;
  transition: color 0.2s;
}
.quote-subtitle a:hover{ color: var(--primary-color); }

/* =========================
   4) WRITE AREA
========================= */
.quote-write-area{
  background:  var(--container-bg-color);
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 30px;
}

.quote-input{
  width: 100%;
  min-height: 100px;
  padding: 15px;

  border: 1px solid var(--input-border-color);
  border-radius: 6px;

  background: var(--form-bg-color);
  color: var(--form-text-color);

  font-size: 0.95em;
  line-height: 1.6;
  resize: vertical;
  font-family: inherit;
}
.quote-input::placeholder{ color: var(--text-muted); opacity: 0.6; }

/* 출처 입력 */
.quote-source-input-area{ margin-top: 10px; }

.quote-source-input{
  width: 100%;
  padding: 10px 15px;

  border: 1px solid var(--input-border-color);
  border-radius: 6px;
  background: var(--form-bg-color);
  color: var(--form-text-color);
  font-size: 0.9em;
}
.quote-source-input::placeholder{ color: var(--text-muted); opacity: 0.6; }

.quote-write-footer{
  display: flex;
  justify-content: space-between;
  align-items: center;
    gap: 5px;
  margin-top: 15px;
}

.quote-options{
  display: flex;
}

/* select 공통 */
.style-select{
  padding: 8px 15px;
  border: 1px solid var(--input-border-color);
  border-radius: 4px;
  background: var(--form-bg-color);
  color: var(--form-text-color);
  font-size: 0.9em;
  cursor: pointer;
  min-width: 0; /* flex 줄바꿈 방지 핵심 */
}

/* 가로 정렬 컨테이너 */
.quote-options,
.style-selects{
  display: flex;
  flex-wrap: nowrap;        /* ⭐ 줄바꿈 금지 */
  gap: 6px;
  align-items: center;
}

/* 모바일에서도 가로 1줄 유지 */
@media (max-width: 768px){
  .style-select{
    padding: 8px 10px;
    font-size: 13px;
    flex: 1 1 0;            /* ⭐ 균등 분배 */
    max-width: none;
  }
}


.quote-submit-btn{
  width:36px;
  height:36px;
  padding:0;
  border: 1px solid var(--container-border-color);
  background: var(--btn-primary-bg);
  border-radius:8px;
  cursor:pointer;
  color: var(--btn-secondary-text);
  transition: all .3s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-size:16px;
}
.quote-submit-btn i{ margin:0; }
.quote-submit-btn:hover{
  background: rgba(100,180,255,0.3);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(100,180,255,0.2);
}

/* =========================
   5) LIST / CARD
========================= */
.quote-list-area{
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-bottom: 40px;
}

/* 카드 레이어 구조 */
.quote-item{
  position: relative;
  isolation: isolate;
  z-index: 0;
  opacity: 0.9;
  background: var(--container-bg-color);
  border: 1px solid var(--card-border-color);
  border-radius: 12px;
  padding: 30px;
  overflow: hidden;
}

/* 배경 이미지(0층) */
.quote-item::before{
  content: '';
  position: absolute;
  inset: 0;

  background-image: var(--quote-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: blur(5px);
  transform: scale(1.03);
  z-index: 0;
  pointer-events: none;
}



/* 어둠 오버레이(1층) */
.quote-item::after{
  content: '';
  position: absolute;
  inset: 0;
  background: var(--container-bg-color);
  opacity: 0.9;
  z-index: 1;
  pointer-events: none;
}

/* 콘텐츠(2층) */
.quote-item > *{
  position: relative;
  z-index: 2;
}

/* 액션 버튼(최상단) */
.quote-actions{
  position: absolute;
  top: 15px;
  right: 15px;
  display: flex;
  gap: 5px;
  z-index: 3;
}

.quote-reply-btn,
.quote-edit-btn,
.quote-delete-btn{
  width: 24px;
  height: 24px;
  border: none;
  background: var(--light-bg-color);
  color: var(--text-muted);
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85em;
}
.quote-reply-btn:hover{ background: var(--accent-color); color: var(--white-color); }
.quote-edit-btn:hover{ background: var(--primary-color); color: var(--white-color); }
.quote-delete-btn:hover{ background: var(--danger-color); color: var(--white-color); }

/* 인용부호 */
.quote-mark-open,
.quote-mark-close{
  color: var(--accent-color);
  font-size: 2em;
  opacity: 0.3;
}
.quote-mark-open{ margin-bottom: 10px; }
.quote-mark-close{ text-align: right; margin-top: 10px; }

/* 본문 */
.quote-content{
  font-size: 1.05em;
  line-height: 1.8;
  color: var(--content-font-color);
  margin: 15px 0;
  padding: 0 20px;
}

/* 정렬 */
.quote-item.quote-align-left   .quote-content{ text-align: left; }
.quote-item.quote-align-center .quote-content{ text-align: center; }
.quote-item.quote-align-right  .quote-content{ text-align: right; }

/* =========================
   6) EDIT AREA
========================= */
.quote-edit-area{
  margin: 15px 0;
  padding: 0 20px;
}

.quote-edit-textarea{
  width: 100%;
  min-height: 100px;
  padding: 15px;

  border: 1px solid var(--input-border-color);
  border-radius: 6px;

  background: var(--card-bg-color);
  color: var(--content-font-color);

  font-size: 0.95em;
  line-height: 1.6;
  resize: vertical;
  font-family: inherit;
}

.quote-edit-source-area{ margin-top: 10px; }

.quote-edit-source-input{
  width: 100%;
  padding: 10px 15px;

  border: 1px solid var(--input-border-color);
  border-radius: 6px;

  background: var(--card-bg-color);
  color: var(--content-font-color);
  font-size: 0.9em;
}

/*  편집 footer: 셀렉트 묶음 + 버튼 오른쪽 */
.quote-edit-footer{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.quote-edit-buttons{
  display: flex;
  gap: 6px;
  margin-left: auto;
}

.quote-edit-area .edit-category-select,
.quote-edit-area .style-select{
  padding: 8px 12px;
  border: 1px solid var(--input-border-color);
  border-radius: 6px;
  background: var(--card-bg-color);
  color: var(--content-font-color);
  font-size: 0.9em;
  cursor: pointer;
  min-width: 120px;
}

.quote-save-btn,
.quote-cancel-btn{
  padding: 8px 15px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.2s;
  font-size: 0.9em;
}

.quote-save-btn{
  background: var(--primary-color);
  color: var(--white-color);
}
.quote-save-btn:hover{ background: var(--primary-hover-color); }

.quote-cancel-btn{
  background: var(--card-bg-color);
  color: var(--content-font-color);
}
.quote-cancel-btn:hover{
  background: var(--card-border-color);
}

.quote-save-btn i,
.quote-cancel-btn i{ margin-right: 5px; }

/* =========================
   7) META (SOURCE / AUTHOR / EMPTY)
========================= */
.quote-source-info{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 25px;
  padding-top: 20px;
  border-top: 1px dotted var(--border-light);
  color: var(--secondary-color);
  font-size: 0.85em;
  font-style: italic;
}

.quote-source-info i{ color: var(--accent-color); opacity: 0.7; }
.source-text{ opacity: 0.8; }

.quote-source-info.quote-source-bottom{
  justify-content: flex-end;
  border-top: 1px dotted var(--border-light);
  margin-top: 18px;
  padding-top: 14px;
  font-size: 0.85em;
  opacity: 0.85;
}
.quote-source-info.quote-source-bottom .source-text{
  max-width: 70%;
  text-align: right;
}

.quote-author{
  text-align: right;
  margin-top: 15px;
  color: var(--secondary-color);
  font-size: 0.9em;
  font-style: italic;
}
.quote-author .character-rank{ color: var(--accent-color); }

.empty-quote-list{
  text-align: center;
  padding: 80px 20px;
  color: var(--text-muted);
}
.empty-quote-list i{
  font-size: 4em;
  color: rgba(var(--primary-color-rgb), 0.15);
  margin-bottom: 20px;
  display: block;
}
.empty-quote-list p{
  font-size: 1.1em;
  margin: 10px 0;
}
.empty-hint{ font-size: 0.95em !important; opacity: 0.7; }

/* =========================
   8) REPLIES
========================= */
.quote-replies{
  margin-top: 25px;
  padding-top: 20px;
  border-top: 1px dashed var(--primary-color);
}

.quote-reply-item{
  padding: 12px 20px;
  background: var(--container-bg-color);
  border-left: 4px solid var(--accent-color);
  margin-bottom: 12px;
  box-shadow: 2px 2px 4px rgba(139,115,85,0.1);

  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.reply-content{
  flex: 1;
  font-size: 0.95em;
  line-height: 1.7;
  color: var(--content-font-color);
  font-family: 'Georgia', serif;
}

.reply-meta{ flex-shrink: 0; }

.reply-delete-btn{
  background: none;
  border: none;
  color: var(--accent-color);
  cursor: pointer;
  padding: 2px 6px;
  font-size: 0.85em;
  transition: color 0.3s;
}
.reply-delete-btn:hover{ color: var(--content-font-color); }

/* 덧글 작성 */
.quote-reply-write{
  margin-top: 15px;
  padding: 15px;
  background: var(--light-bg-color);
  border-radius: 6px;
}

.reply-input{
  width: 100%;
  min-height: 60px;
  padding: 10px;

  border: 1px solid var(--input-border-color);
  border-radius: 4px;

  background: var(--bg-color);
  color: var(--content-font-color);
  font-size: 0.9em;
  line-height: 1.5;
  resize: vertical;
  font-family: inherit;
}
.reply-input::placeholder{ color: var(--text-muted); opacity: 0.6; }

.reply-write-footer{
  display: flex;
  justify-content: flex-end;
  gap: 5px;
  margin-top: 10px;
}

.reply-submit-btn,
.reply-cancel-btn{
  padding: 6px 15px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.85em;
  transition: all 0.2s;
}

.reply-submit-btn{
  background: var(--primary-color);
  color: var(--white-color);
}
.reply-submit-btn:hover{ background: var(--primary-hover-color); }

.reply-cancel-btn{
  background: var(--card-border-color);
  color: var(--content-font-color);
}
.reply-cancel-btn:hover{
  background: var(--text-muted);
  color: var(--white-color);
}

/* =========================
   9) QUOTE TEXT EFFECTS
========================= */
/* 1) 기본 */
.quote-style-default .quote-content{
  font-style: normal;
  letter-spacing: normal;
}

/* 2) 명조체 */
.quote-style-serif .quote-content{
  font-family: 'Noto Serif KR','Georgia',serif;
  font-size: 1.1em;
}

/* 3) 반짝이 */
.quote-style-highlight .quote-content{
  position: relative;
  background: transparent !important;
}
@keyframes blink {
  0%   { opacity: 0; }
  7%   { opacity: 0.5; }
  12%  { opacity: 1; }
  28%  { opacity: 1; }
  33%  { opacity: 0; }
  47%  { opacity: 1; }
  52%  { opacity: 1; }
  71%  { opacity: 0; }
  76%  { opacity: 0.5; }
  100% { opacity: 1; }
}

/* 글자 자체 blink */
.quote-style-highlight .quote-content{
  animation: blink 6.7s infinite; /* 1초 간격으로 무한 반복 */
}

/* 4) 기울임 */
.quote-style-italic .quote-content{
  font-style: italic;
  letter-spacing: 0.02em;
}

/* 5) 속삭임 */
.quote-style-whisper .quote-content{
  opacity: 0.85;
  letter-spacing: 0.04em;
  text-shadow:
    0 0 8px rgba(255,255,255,0.08),
    0 1px 2px rgba(0,0,0,0.6);
}

/* 6) 강한 문장 */
.quote-style-boldline .quote-content{
  font-weight: 600;
  letter-spacing: 0.02em;
  border-left: 4px solid var(--accent-color);
  padding-left: 14px;
}

/* 7) 글로우 */
.quote-style-glow .quote-content{
  color: rgba(255,255,255,0.95);
  text-shadow:
    0 0 6px rgba(180,160,255,0.35),
    0 0 18px rgba(120,100,255,0.15);
}

/* 8) 프랙처 */
.quote-style-fracture .quote-content{
  position: relative;
  text-shadow:
    -1px 0 rgba(255,0,0,0.25),
     1px 0 rgba(0,255,255,0.25);
}

/* 9) 스크립트 */
.quote-style-script .quote-content{
  font-family: 'Playfair Display','Georgia',serif;
  font-style: italic;
  letter-spacing: 0.06em;
}

/* =========================
   10) RESPONSIVE
========================= */
@media (max-width: 768px){
  .quote-title{ font-size: 3em; }

  .quote-item{ padding: 20px; }
  .quote-item::before{ filter:none; opacity:0.35; }

  .quote-content{
    font-size: 1em;
    padding: 0 10px;
  }

  .quote-options{
    width: 100%;
  }

  .style-select{
    width: 100%;
  }

  /* 편집영역 */
  .quote-edit-buttons{
    margin-left: 0;
    width: 100%;
    justify-content: flex-end;
  }
  .quote-edit-area .edit-category-select,
  .quote-edit-area .style-select{
    flex: 1 1 0;
    min-width: 0;
  }
}
/* 모바일: blur 제거 + opacity 낮추기 */
@media (max-width: 768px){
  .quote-style-highlight .quote-content::before{
    filter: none;
    opacity: 0.35;
    animation-duration: 18s; /* 더 느리게 */
  }
}

/* 사용자가 OS에서 "동작 줄이기" 켠 경우: 애니메이션 OFF */
@media (prefers-reduced-motion: reduce){
  .quote-style-highlight .quote-content::before{
    animation: none;
    transform: translate3d(0, 0, 0);
    opacity: 0.25;
  }
}
