:root{
  --navy:#1a55e6;
  --blue:#1e63ff;
  --electric:#00a8ff;
  --silver:#c7d3e8;
  --ink:#0c1024;
  --bg:#000000;
  --card:#1a1a1a;
  --line:rgba(255,255,255,.08);
  --text:#e8ecf5;
  --muted:#8fa3c8;
  --accent:linear-gradient(135deg, var(--blue) 0%, var(--electric) 100%);
  --shadow:0 10px 30px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.04);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:'Noto Sans KR', 'Poppins', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.5;
  font-size:14px;
}

.container{width:min(1200px, 92%); margin:0 auto}



.search input{background:#0b1430; border:1px solid var(--line); color:var(--text); padding:8px 10px; border-radius:8px; width:220px}
.btn{display:inline-flex; align-items:center; gap:6px; padding:8px 12px; border-radius:8px; text-decoration:none; color:#fff; border:1px solid transparent; cursor:pointer; min-height:36px; transition:all .2s ease}
.btn-sm{padding:6px 10px; font-size:.9rem}
.btn-primary{background:var(--blue); border-color:rgba(0,0,0,.15)}
.btn-outline{background:transparent; border-color:var(--line)}
.btn-ghost{background:transparent; color:var(--muted)}

/* Layout */
.layout{display:grid; grid-template-columns:260px 1fr; gap:14px; padding:16px 0}
.sidebar{display:flex; flex-direction:column; gap:14px}


/* 모바일에서 데스크톱 사이드바 숨김 */
.desktop-only{
  display:block;
}

/* 추가 터치 최적화 */
@media (max-width:1024px){
  /* 터치 영역 최소 44px 보장 */
  .btn,
  .tab{
    min-height:44px;
    display:flex;
    align-items:center;
  }
  
  /* 터치 피드백 개선 */
  .btn:active{
    transform:scale(.98);
  }
  
  
  
  
}
.card{background:var(--card); border:1px solid var(--line); border-radius:12px; box-shadow:0 6px 16px rgba(0,0,0,.35); padding:12px; color:var(--text)}
.card h3{margin:0 0 8px; font-size:1rem; color:var(--text)}

/* Left widgets */
.ranking ol{padding-left:18px; margin:0}
.ranking li{margin:6px 0}
.quick-links ul{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.quick-links a{color:var(--blue); text-decoration:none}


.tabs{display:flex; gap:8px}
.tabs button{background:var(--card); color:var(--muted); border:1px solid var(--line); border-radius:8px; padding:6px 10px; cursor:pointer; min-height:36px; transition:all .2s ease}
.tabs button.active{background:var(--blue); color:#fff}

.media{display:grid; grid-template-columns:240px 1fr; gap:12px; padding:12px; background:var(--card); color:var(--text); border:1px solid var(--line); border-radius:12px}
.media h3{margin:0 0 6px; color:var(--text)}
.media img{width:100%; height:100%; object-fit:cover; border-radius:10px}

.cards{display:grid; grid-template-columns:repeat(4,1fr); gap:12px}
.tile{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:16px; text-decoration:none; color:var(--text); transition:transform .2s ease, box-shadow .2s ease}
.tile:hover{transform:translateY(-2px); box-shadow:0 12px 22px rgba(0,0,0,.4)}

.masonry{columns:3 280px; column-gap:12px}
.masonry img{width:100%; margin:0 0 12px; border-radius:12px; display:block}

/* Content area dark background */
.content{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:12px; color:var(--text)}
.content .section-header h2{color:var(--text)}
.content .section-header .more{color:var(--blue)}
.content .tabs button{background:var(--card); border-color:var(--line); color:var(--muted)}
.content .tabs button.active{background:var(--blue); color:#fff}
.content .grid{margin-top:8px}

/* 공지 배지 */
.badge-notice{color:#ff6b6b; margin-right:8px; font-weight:700}

/* 2열 섹션 */
.row.two-col{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.row.two-col .col{background:var(--card); border:1px solid var(--line); border-radius:10px; padding:10px}
/* 3열 섹션 (인기글/자유게시판/직관 후기) */
.row.two-col:has(.col:nth-child(3)){grid-template-columns:1fr 1fr 1fr}
/* 단일 컬럼 섹션 */
.row:not(.two-col) .col{background:var(--card); border:1px solid var(--line); border-radius:10px; padding:10px}



/* Right widgets */
.ticker{list-style:none; padding:0; margin:0; height:120px; overflow:hidden}
.ad-box{height:120px; background:repeating-linear-gradient(45deg, #0e183f, #0e183f 10px, #122056 10px, #122056 20px); border-radius:12px; display:flex; align-items:center; justify-content:center; color:#9fb0d0}

/* Footer */
.site-footer{margin-top:16px; border-top:1px solid var(--line); background:var(--bg)}
.site-footer .container{display:flex; align-items:center; justify-content:space-between; padding:12px 0; color:var(--muted)}
.footer-nav a{color:var(--muted); margin-left:12px; text-decoration:none}

/* Back to top */
.back-to-top{position:fixed; right:18px; bottom:18px; width:42px; height:42px; border-radius:50%; border:1px solid var(--line); background:#0b1430; color:#fff; display:none; align-items:center; justify-content:center; cursor:pointer; box-shadow:var(--shadow)}
.back-to-top.show{display:flex}

/* 로그인 모달창 */
.login-modal{position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.7); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; z-index:2000}
.login-modal-content{background:var(--card); border-radius:14px; width:400px; max-width:90%; box-shadow:0 20px 40px rgba(0,0,0,.5); border:1px solid var(--line)}
.login-modal-header{display:flex; align-items:center; justify-content:space-between; padding:20px 24px 16px; border-bottom:1px solid var(--line)}
.login-modal-header h2{margin:0; color:var(--text); font-size:1.3rem; font-weight:600}
.login-modal-close{background:none; border:none; font-size:20px; color:var(--text); cursor:pointer; padding:0; width:32px; height:32px; display:flex; align-items:center; justify-content:center; border-radius:8px; transition:background .2s ease}
.login-modal-close:hover{background:rgba(255,255,255,.1); color:var(--text)}
.login-modal-body{padding:24px}

/* 문의 모달 */
.contact-modal{position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,.7); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; z-index:2000}
.contact-modal-content{background:var(--card); border-radius:14px; width:400px; max-width:90%; box-shadow:0 20px 40px rgba(0,0,0,.5); border:1px solid var(--line); max-height:90vh; overflow-y:auto}
.contact-modal-content.contact-modal-large{width:600px; max-width:95%}
.contact-modal-header{display:flex; align-items:center; justify-content:space-between; padding:20px 24px 16px; border-bottom:1px solid var(--line); position:sticky; top:0; background:var(--card); z-index:10}
.contact-modal-header h2{margin:0; color:var(--text); font-size:1.3rem; font-weight:600}
.contact-modal-close{background:none; border:none; font-size:20px; color:var(--text); cursor:pointer; padding:0; width:32px; height:32px; display:flex; align-items:center; justify-content:center; border-radius:8px; transition:background .2s ease}
.contact-modal-close:hover{background:rgba(255,255,255,.1); color:var(--text)}
.contact-modal-body{padding:24px; text-align:left}
.contact-intro{color:var(--text); font-size:0.95rem; margin-bottom:24px; line-height:1.7; text-align:center}
.contact-section{margin-bottom:28px}
.contact-section:last-child{margin-bottom:0}
.contact-section-title{color:var(--text); font-size:1.1rem; font-weight:600; margin-bottom:12px; padding-bottom:8px; border-bottom:1px solid var(--line)}
.contact-list{list-style:none; padding:0; margin:0}
.contact-list li{color:var(--text); font-size:0.9rem; line-height:1.8; padding:6px 0; padding-left:20px; position:relative}
.contact-list li:before{content:'•'; position:absolute; left:0; color:var(--blue); font-weight:bold}
.contact-email{margin:16px 0}
.contact-email-link{display:inline-block; padding:12px 24px; background:var(--blue); color:#fff; text-decoration:none; border-radius:8px; font-size:1rem; font-weight:600; transition:all .2s ease}
.contact-email-link:hover{background:#2563eb; transform:translateY(-2px); box-shadow:0 4px 12px rgba(30,99,255,.3)}
.contact-form-note{color:var(--muted); font-size:0.9rem; margin:16px 0 12px; line-height:1.6}
.contact-form-template{background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:8px; padding:16px; margin-top:12px}
.contact-form-template p{color:var(--text); font-size:0.9rem; margin:8px 0; line-height:1.6; font-family:monospace}
.login-input-group{margin-bottom:16px}
.login-input-group input{width:100%; padding:14px 18px; background:rgba(255,255,255,.05); border:1px solid var(--line); border-radius:10px; font-size:0.95rem; color:var(--text); box-sizing:border-box; transition:all .2s ease}
.login-input-group input::placeholder{color:var(--muted)}
.login-input-group input:focus{outline:none; border-color:var(--blue); background:rgba(255,255,255,.08); box-shadow:0 0 0 3px rgba(30,99,255,.2)}
.login-options{display:flex; align-items:center; justify-content:space-between; margin-bottom:24px}
.login-checkboxes{display:flex; gap:16px}
.login-checkbox{display:flex; align-items:center; gap:6px; font-size:0.85rem; color:var(--text); cursor:pointer; user-select:none}
.login-checkbox input[type="checkbox"]{display:none}
.login-checkbox .checkmark{width:16px; height:16px; background:rgba(255,255,255,.05); border:1px solid var(--line); border-radius:3px; margin-right:6px; position:relative; transition:all .2s ease}
.login-checkbox input[type="checkbox"]:checked + .checkmark{background:rgba(255,255,255,.1); border-color:var(--line)}
.login-checkbox input[type="checkbox"]:checked + .checkmark::after{content:'✓'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); color:var(--text); font-size:12px; font-weight:bold}
.login-link{color:var(--blue); text-decoration:none; font-size:0.85rem; transition:color .2s ease}
.login-link:hover{color:var(--muted); text-decoration:none}
.login-actions{display:flex; gap:12px}
.login-btn{flex:1; padding:12px 16px; border:none; border-radius:8px; font-size:14px; font-weight:600; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; transition:all .2s ease}
.signup-btn{background:var(--blue); color:#fff; border:1px solid var(--blue)}
.signup-btn:hover{background:#1a55e6; border-color:#1a55e6}
.login-submit-btn{background:#3a3d4a; color:#fff; border:1px solid #4a4d5a}
.login-submit-btn:hover{background:#4a4d5a; border-color:#5a5d6a}
.btn-icon{font-size:16px}


/* Responsive */
@media (max-width:1100px){
  .layout{grid-template-columns:220px 1fr}
  .media{grid-template-columns:200px 1fr}
}

/* 태블릿 (768px 이하) */
@media (max-width:1024px){
  .layout{
    grid-template-columns:1fr;
    gap:10px;
    padding:10px 0;
  }
  .desktop-only{
    display:none;
  }
  .content{
    padding:10px;
    margin-top:20px;
  }
}

/* 모바일 환경 (768px 이하) */
@media (max-width:768px){
  .content{
    margin-top:20px;
  }
}

/* 패드 환경 (768px~1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  .content {
    margin-top: 24px;
  }
}
  .hero{
    min-height:80px;
    margin-bottom:12px;
  }
  .hero-text{
    padding:16px;
  }
  .hero h1{
    font-size:1.3rem;
    line-height:1.3;
  }
  .hero p{
    font-size:.85rem;
    line-height:1.4;
  }
  .section-header{
    margin:10px 0 6px;
  }
  .section-header h2{
    font-size:1.1rem;
    line-height:1.3;
  }
  .row.two-col{
    grid-template-columns:1fr;
    gap:10px;
  }
  .row.two-col:has(.col:nth-child(3)){
    grid-template-columns:1fr;
  }
  .btn{
    min-height:40px;
    padding:10px 14px;
    font-size:15px;
  }
  .card{
    padding:10px;
  }
  .badge-notice{
    font-size:1rem;
    white-space:nowrap;
  }


/* 모바일 (480px 이하) */
@media (max-width:480px){
  .container{
    width:95%;
  }
  .content{
    margin-top:20px;
  }
  .badge-notice{
    font-size:.7rem;
    white-space:nowrap;
  }
  .cards{
    grid-template-columns:1fr;
    gap:6px;
  }
  .tile{
    padding:10px;
  }
  .back-to-top{
    width:44px;
    height:44px;
    right:10px;
    bottom:10px;
  }
  .card{
    padding:8px;
  }
  .card h3{
    font-size:.95rem;
    margin-bottom:8px;
  }
}

/* 토스트 메시지 스타일 */
.toast {
  position: fixed;
  top: 20px;
  right: 20px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px 20px;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  gap: 12px;
  z-index: 10000;
  min-width: 300px;
  max-width: 400px;
  opacity: 0;
  transform: translateX(400px);
  transition: all 0.3s ease;
}

.toast.show {
  opacity: 1;
  transform: translateX(0);
}

.toast-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.toast.success {
  border-left: 4px solid #27ae60;
}

.toast.success .toast-icon {
  color: #27ae60;
}

.toast.error {
  border-left: 4px solid #e74c3c;
}

.toast.error .toast-icon {
  color: #e74c3c;
}

.toast.info {
  border-left: 4px solid var(--blue);
}

.toast.info .toast-icon {
  color: var(--blue);
}

.toast.warning {
  border-left: 4px solid #f39c12;
}

.toast.warning .toast-icon {
  color: #f39c12;
}

.toast-content {
  flex: 1;
}

.toast-message {
  color: var(--text);
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.4;
}

.toast-close {
  background: none;
  border: none;
  color: var(--muted);
  cursor: pointer;
  font-size: 18px;
  padding: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: color 0.2s ease;
}

.toast-close:hover {
  color: var(--text);
}

@media (max-width: 480px) {
  .toast {
    top: 10px;
    right: 10px;
    left: 10px;
    min-width: auto;
    max-width: none;
    transform: translateY(-100px);
  }
  
  .toast.show {
    transform: translateY(0);
  }
}

