:root{
  --bg:#000080;
  --bg-dark:#000050;
  --panel:#0000aa;
  --border:#00aaff;
  --border-bright:#ffffff;
  --text:#ffffff;
  --text-dim:#aaaaaa;
  --accent-cyan:#00ffff;
  --accent-yellow:#ffff00;
  --accent-green:#00ff00;
  --accent-red:#ff5555;
  --accent-magenta:#ff55ff;
}

.glroot{
  background:var(--bg-dark);
  color:var(--text);
  font-family:'Share Tech Mono','Nanum Gothic Coding', monospace;
  font-size:14px;
  padding-bottom:30px;
}

/* scanline */
.glroot::before{
  content:'';
  position:fixed; inset:0;
  background:repeating-linear-gradient(
    0deg, transparent, transparent 2px,
    rgba(0,0,0,0.10) 2px, rgba(0,0,0,0.10) 4px
  );
  pointer-events:none;
  z-index:9999;
}

.top-bar{
  background:var(--panel);
  border-bottom:2px solid var(--accent-cyan);
  padding:2px 8px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:12px;
}
.top-bar .logo{
  background:var(--accent-cyan);
  color:#000;
  padding:0 6px;
  font-weight:bold;
  letter-spacing:1px;
}
.top-bar .title-center{
  color:var(--accent-yellow);
  font-size:13px;
  letter-spacing:2px;
}
.top-bar .site-name{ color:var(--accent-cyan); }

.main-wrapper{ max-width:980px; margin:0 auto; padding:10px; }

.user-panel{
  background:var(--bg-dark);
  border:1px solid var(--border);
  padding:4px 10px;
  margin-bottom:8px;
  display:flex;
  gap:16px;
  align-items:center;
  font-size:12px;
  flex-wrap:wrap;
}
.user-nick{ color:var(--accent-cyan); }
.user-lv{ color:var(--accent-yellow); }
.user-time{ margin-left:auto; color:var(--text-dim); font-size:11px; }

/* 공통 박스 */
.bbs-box{
  border:1px solid var(--border);
  background:var(--panel);
  margin-bottom:8px;
}
.bbs-box-title{
  background:var(--bg-dark);
  border-bottom:1px solid var(--border);
  padding:2px 8px;
  color:var(--accent-yellow);
  text-align:center;
  letter-spacing:4px;
  font-size:13px;
}

/* ✅ 대시보드 3단 */
.dash-grid{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap:8px;
  margin-bottom:8px;
}
@media (max-width: 980px){
  .dash-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px){
  .dash-grid{ grid-template-columns: 1fr; }
}

/* mini list (최근/인기) */
.mini-list{ padding:6px 8px 8px; }
.mini-item{
  display:flex;
  flex-direction:column;
  gap:2px;
  padding:6px 6px;
  border-bottom:1px solid #222244;
  text-decoration:none;
  color:var(--text);
}
.mini-item:hover{ background:#111155; }
.mini-num{
  color:var(--text-dim);
  font-size:12px;
}
.mini-title{
  color:var(--text);
  font-size:13px;
  line-height:1.3;
}
.mini-item:hover .mini-title{ color:var(--accent-cyan); text-decoration:underline; }
.mini-meta{
  color:var(--text-dim);
  font-size:11px;
}
.mini-empty{
  padding:10px;
  color:var(--text-dim);
}

.tag-new{
  display:inline-block;
  margin-left:6px;
  padding:0 6px;
  border:1px solid var(--accent-red);
  color:var(--accent-red);
  font-size:11px;
  letter-spacing:1px;
}

/* 빠른이동 */
.quick-box{ padding:8px 10px; }
.quick-row{
  display:grid;
  grid-template-columns: 50px 90px 1fr;
  gap:8px;
  padding:4px 0;
  border-bottom:1px dashed rgba(255,255,255,.15);
  font-size:12px;
}
.quick-key{ color:var(--text-dim); }
.quick-val{ color:var(--accent-green); }
.quick-desc{ color:var(--text); }
.quick-tip{
  grid-template-columns: 1fr;
  color:var(--text-dim);
  border-bottom:none;
  padding-top:8px;
}

/* 카테고리 그리드 */
.category-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}
.cat-section{ border-right:1px solid var(--border); padding:6px 10px; }
.cat-section:last-child{ border-right:none; }
.cat-header{
  background:#333399;
  border:1px solid var(--border-bright);
  text-align:center;
  margin-bottom:6px;
  padding:1px 0;
  font-size:13px;
  letter-spacing:3px;
  color:var(--accent-yellow);
}

.cat-item{
  display:flex;
  align-items:flex-start;
  gap:6px;
  margin-bottom:3px;
  line-height:1.4;
  text-decoration:none;
}
.cat-num{ color:var(--text-dim); min-width:64px; font-size:13px; }
.cat-name{ color:var(--text); font-size:13px; }
.cat-item:hover .cat-num{ color:var(--accent-yellow); }
.cat-item:hover .cat-name{ color:var(--accent-cyan); text-decoration:underline; }
.cat-name.highlight{ color:var(--accent-green); }
.cat-name.highlight2{ color:var(--accent-magenta); }
.cat-name.highlight3{ color:var(--accent-cyan); }

.cat-more{ margin-top:6px; }
.cat-empty{ padding:12px; color:var(--text-dim); }

.cmd-bar{
  background:var(--panel);
  border:1px solid var(--border);
  padding:6px 10px;
  margin-bottom:8px;
}
.cmd-bar-text{ color:var(--text-dim); font-size:12px; margin-bottom:4px; }
.cmd-input-row{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.cmd-prompt{ color:var(--accent-green); white-space:nowrap; font-size:14px; }
.cmd-input{
  background:transparent;
  border:none;
  border-bottom:1px solid var(--accent-green);
  color:var(--accent-green);
  font-family:inherit;
  font-size:14px;
  outline:none;
  flex:1;
  padding:0 2px;
  min-width:220px;
}

.bbs-btn{
  background:var(--panel);
  border:1px solid var(--border);
  color:var(--text);
  font-family:inherit;
  font-size:12px;
  padding:3px 10px;
  cursor:pointer;
  text-decoration:none;
  display:inline-block;
}
.bbs-btn:hover{ background:var(--border); color:#000; }
.bbs-btn.primary{ border-color:var(--accent-cyan); color:var(--accent-cyan); }
.bbs-btn.primary:hover{ background:var(--accent-cyan); color:#000; }
.bbs-btn.success{ border-color:var(--accent-green); color:var(--accent-green); }
.bbs-btn.success:hover{ background:var(--accent-green); color:#000; }

/* 모바일 */
@media (max-width:600px){
  .category-grid{ grid-template-columns: 1fr; }
  .cat-section{ border-right:none; border-bottom:1px solid var(--border); }
}

/* =========================
   Bootstrap container(흰 여백) 탈출
   - base.html의 <main class="container"> 때문에 생기는 좌우 여백 제거
   ========================= */
.glroot{
  /* container padding 상쇄 */
  margin-left: calc(-1 * var(--bs-gutter-x, 0.75rem));
  margin-right: calc(-1 * var(--bs-gutter-x, 0.75rem));
  padding-left: var(--bs-gutter-x, 0.75rem);
  padding-right: var(--bs-gutter-x, 0.75rem);

  /* 화면 전체 CRT 느낌 */
  min-height: calc(100vh - 120px); /* navbar/footer 대충 보정 */
}

/* 바깥 흰 부분까지 어둡게 보이게(글룸 페이지에서만) */
.glroot::after{
  content:"";
  position:fixed;
  inset:0;
  background: radial-gradient(ellipse at center, rgba(0,0,0,0) 0%, rgba(0,0,0,0.35) 70%, rgba(0,0,0,0.65) 100%);
  pointer-events:none;
  z-index:9998;
}

/* =========================
   댓글 UI 강화
   ========================= */
.comment-box{
  border:1px solid var(--border);
  background: #000033;
  margin-top:10px;
  margin-bottom:10px;
}

.comment-header{
  background:#111166;
  padding:4px 10px;
  color:var(--accent-cyan);
  font-size:12px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.comment-count{
  color:var(--accent-yellow);
  font-weight:bold;
}

.comment-item{
  padding:10px 12px;
  border-bottom:1px solid #222244;
  font-size:13px;
  line-height:1.55;
}

.comment-item:nth-child(even){
  background: rgba(0, 255, 255, 0.03);
}

.comment-meta{
  display:flex;
  gap:10px;
  align-items:center;
  margin-bottom:6px;
  font-size:12px;
}

.comment-author{
  color:var(--accent-magenta);
  font-weight:bold;
}

.comment-date{
  color:var(--text-dim);
  font-size:11px;
}

.comment-no{
  color:var(--text-dim);
  font-size:11px;
  margin-left:auto;
}

.comment-text{
  color:var(--text);
  white-space:pre-wrap;
}

.comment-write{
  padding:10px 12px;
  border-top:1px solid var(--border);
  background:#000022;
}

.comment-write-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px;
  color:var(--text-dim);
  font-size:12px;
}

.comment-input{
  width:100%;
  background:#000033;
  border:1px solid var(--border);
  color:var(--accent-green);
  font-family:inherit;
  font-size:13px;
  padding:8px 10px;
  outline:none;
  resize:vertical;
  min-height:80px;
  line-height:1.5;
}

.comment-actions{
  display:flex;
  justify-content:flex-end;
  gap:8px;
  margin-top:8px;
}

/* 작은 버튼 느낌 더 레트로하게 */
.bbs-btn{
  letter-spacing:1px;
}

/* 모바일에서 글/댓글 여백 정리 */
@media (max-width:600px){
  .main-wrapper{ padding:8px; }
  .comment-item{ padding:10px 10px; }
  .comment-write{ padding:10px 10px; }
}

.post-body{
  box-shadow: inset 0 0 0 1px rgba(0,255,255,0.12);
}

/* =========================
   Board list (글 목록)
   ========================= */
.board-head{
  display:flex;
  gap:10px;
  justify-content:space-between;
  align-items:flex-start;
  padding:10px;
  border-bottom:1px solid var(--border);
  background:#000044;
  flex-wrap:wrap;
}
.board-head-left{ font-size:12px; }
.board-search{ display:flex; gap:8px; flex-wrap:wrap; justify-content:flex-end; }

.dim{ color:var(--text-dim); }
.cyan{ color:var(--accent-cyan); }
.yellow{ color:var(--accent-yellow); }

.bbs-input{
  background:#000033;
  border:1px solid var(--border);
  color:var(--accent-green);
  font-family:inherit;
  font-size:13px;
  padding:6px 8px;
  outline:none;
  min-width:240px;
}
.bbs-textarea{
  width:100%;
  background:#000033;
  border:1px solid var(--border);
  color:var(--accent-green);
  font-family:inherit;
  font-size:13px;
  padding:8px 10px;
  outline:none;
  resize:vertical;
  min-height:120px;
  line-height:1.5;
}

.bbs-table-wrap{ padding:10px; }
.bbs-table{
  width:100%;
  border-collapse:collapse;
  background:#000033;
  border:1px solid var(--border);
}
.bbs-table thead th{
  background:#111166;
  color:var(--accent-yellow);
  font-size:12px;
  padding:6px 8px;
  border-bottom:1px solid var(--border);
  letter-spacing:2px;
}
.bbs-table tbody td{
  padding:7px 8px;
  border-bottom:1px solid #222244;
  font-size:13px;
  vertical-align:top;
}
.bbs-table tbody tr:nth-child(even){
  background: rgba(0,255,255,0.03);
}

.col-no{ width:70px; color:var(--text-dim); text-align:right; }
.col-author{ width:120px; color:var(--accent-magenta); }
.col-date{ width:80px; color:var(--text-dim); }
.col-views{ width:70px; color:var(--text-dim); text-align:right; }

.bbs-link{
  color:var(--accent-cyan);
  text-decoration:none;
}
.bbs-link:hover{ text-decoration:underline; }

.badge-count{
  color:var(--accent-yellow);
  margin-left:6px;
  font-size:12px;
}

.empty-row{
  text-align:center;
  color:var(--text-dim);
  padding:12px;
}

.pager{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px;
  border-top:1px solid var(--border);
  background:#000044;
  flex-wrap:wrap;
  gap:10px;
}

.form-hint{
  padding:8px 10px;
  color:var(--text-dim);
  font-size:12px;
}
.bbs-form{ padding:10px; }
.bbs-form-row{
  display:grid;
  grid-template-columns: 80px 1fr;
  gap:10px;
  align-items:start;
  margin-bottom:10px;
}
.bbs-label{
  color:var(--accent-yellow);
  font-size:12px;
  padding-top:6px;
}
.bbs-form-actions{
  display:flex;
  justify-content:flex-end;
}

/* 모바일에서는 컬럼 줄이기 */
@media (max-width:720px){
  .col-views{ display:none; }
  .col-author{ width:90px; }
  .bbs-input{ min-width:180px; }
}
@media (max-width:520px){
  .col-date{ display:none; }
  .col-author{ display:none; }
  .bbs-form-row{ grid-template-columns: 1fr; }
  .bbs-label{ padding-top:0; }
}

/* =========================
   CRT 효과 OFF (가독성 우선)
   ========================= */
.glroot::before{ display:none !important; } /* scanline 제거 */
.glroot::after{ display:none !important; }  /* 비네팅 제거 */

:root{
  --bg-dark:#000061;   /* 기존 #000050 보다 살짝 밝게 */
  --panel:#0000a3;     /* 기존 #0000aa 살짝 완화 */
  --border:#2fb6ff;    /* 너무 쨍한 하늘색 살짝 부드럽게 */
}

.notice-box{
  border:1px solid var(--border);
  background:#000033;
  margin:10px;
  padding:8px 10px;
}
.notice-title{
  color:var(--accent-yellow);
  letter-spacing:3px;
  text-align:center;
  margin-bottom:8px;
  font-size:12px;
}
.notice-row{
  display:flex;
  gap:8px;
  align-items:center;
  padding:6px 6px;
  border-bottom:1px solid #222244;
}
.notice-row:last-child{ border-bottom:none; }
.notice-rank{ color:var(--accent-red); }

.post-image-wrap{
  margin-top:10px;
  border:1px solid var(--border);
  background:#000022;
  padding:10px;
}
.post-image{
  display:block;
  max-width:100%;
  height:auto;
  border:1px solid rgba(255,255,255,.2);
}

/* category list */
.board-list-item{
  display:flex;
  gap:10px;
  align-items:center;
  padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.board-list-item:hover{ background: rgba(0,255,255,.03); }
.board-list-num{ color:var(--text-dim); width:40px; text-align:right; }
.board-list-name{ color:var(--accent-cyan); text-decoration:none; }
.board-list-name:hover{ text-decoration:underline; }
.board-list-count{ margin-left:auto; color:var(--accent-yellow); font-size:12px; }

/* inputs used in category.html */
.form-ctrl{
  background:#000033;
  border:1px solid var(--border);
  color:var(--accent-green);
  font-family:inherit;
  font-size:13px;
  padding:6px 8px;
  outline:none;
}
.form-ctrl::placeholder{ color: rgba(170,170,170,.75); }

.gl-msg{
  border:1px solid var(--border);
  background:#000033;
  color:var(--text);
  padding:8px 10px;
  margin:8px 0;
  font-size:13px;
}
.gl-msg-error{ border-color: var(--accent-red); color: var(--accent-red); }
.gl-msg-success{ border-color: var(--accent-green); color: var(--accent-green); }
.gl-msg-warning{ border-color: var(--accent-yellow); color: var(--accent-yellow); }

/* post detail prev/next */
.pn-nav{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  margin:12px 0 14px;
}
.pn-item{
  display:block;
  padding:10px 12px;
  border:1px solid var(--line);
  background: rgba(0,0,0,.25);
  text-decoration:none;
  color: var(--text);
}
.pn-item:hover{ border-color: var(--cyan); }
.pn-item.disabled{
  opacity:.55;
}
.pn-label{
  display:block;
  font-size:12px;
  color: var(--text-dim);
  margin-bottom:6px;
}
.pn-title{
  display:block;
  font-size:14px;
  color: var(--yellow);
  word-break:break-word;
}
@media (max-width: 640px){
  .pn-nav{ grid-template-columns:1fr; }
}

.login-link{
  color: var(--cyan);
  text-decoration: underline;
  font-weight: 700;
}
.login-link:hover{
  color: var(--yellow);
}