/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:#0a0a0a;color:#fff;overflow:hidden;height:580px}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 800px 600px at 80% 50%,rgba(122,31,43,.22),transparent 60%),
    radial-gradient(ellipse 600px 400px at 10% 90%,rgba(184,147,90,.08),transparent 60%),
    linear-gradient(135deg,#0a0a0a 0%,#161616 100%);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.012) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.012) 1px,transparent 1px);
  background-size:80px 80px;
}
.ribbon-art{
  position:absolute;right:6%;top:50%;transform:translateY(-50%);
  width:380px;height:380px;opacity:.95;filter:drop-shadow(0 30px 60px rgba(0,0,0,.6));
}
.hero-row{position:relative;height:100%;display:flex;flex-direction:column;justify-content:center;z-index:2;max-width:760px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;border:1px solid rgba(255,255,255,.18);
  border-radius:30px;font-size:11px;letter-spacing:.25em;
  margin-bottom:28px;width:fit-content;color:var(--gold);
  font-family:'Inter';font-weight:500;background:rgba(255,255,255,.02);
}
.hero-eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--gold)}
.hero h1{
  font-family:'Noto Serif KR',serif;font-size:48px;font-weight:600;
  line-height:1.35;margin-bottom:24px;letter-spacing:-.025em;color:#fff;
}
.hero h1 em{color:var(--gold);font-style:normal;font-weight:700}
.hero p.lead{font-size:16px;color:#a8a8a8;max-width:540px;margin-bottom:38px;line-height:1.8}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}

.slide-ctrl{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;align-items:center;gap:18px;z-index:3;
  font-size:12px;color:#666;font-family:'Inter';font-weight:500;letter-spacing:.1em;
}
.slide-dots{display:flex;gap:6px}
.slide-dot{width:24px;height:2px;background:rgba(255,255,255,.2);cursor:pointer;transition:all var(--t);border-radius:2px}
.slide-dot.on{background:var(--gold);width:36px}

/* =========================================================
   QUICK MENU
   ========================================================= */
.quick-wrap{position:relative;z-index:5;margin-top:-58px;margin-bottom:30px}
.quick-grid{
  display:grid;grid-template-columns:repeat(6,1fr);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);overflow:hidden;
}
.quick-item{
  padding:34px 18px 30px;text-align:center;
  border-right:1px solid var(--line-soft);cursor:pointer;
  transition:all var(--t);position:relative;background:#fff;
  text-decoration:none;color:inherit;
}
.quick-item:last-child{border-right:none}
.quick-item:hover{background:var(--bg-soft)}
.quick-item:hover .qi-icon{background:var(--ink);color:#fff;transform:translateY(-3px)}
.qi-icon{
  width:54px;height:54px;border-radius:50%;background:var(--bg-mute);
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;
  color:var(--brand);transition:all var(--t);font-size:22px;
}
.qi-label{font-size:13.5px;font-weight:600;color:var(--text);line-height:1.4}
.qi-arrow{
  position:absolute;top:14px;right:14px;color:var(--text-4);font-size:11px;
  transition:var(--t);font-family:'Inter';
}
.quick-item:hover .qi-arrow{color:var(--brand);transform:translate(2px,-2px)}

/* ===== ★ B-7: SIREN 그룹 디자인 (사건/악성/법률) ===== */
.quick-item.siren-item{
  background:linear-gradient(180deg,#fff 0%,#fef9f5 100%);
  border-bottom:3px solid #c5293a;
  padding-top:48px;
}
.quick-item.siren-item:hover{
  background:linear-gradient(180deg,#fef9f5 0%,#fce8eb 100%);
}
.quick-item.siren-item .qi-icon{
  background:linear-gradient(135deg,#fce8eb,#fef9f5);
  color:#c5293a;
}
.quick-item.siren-item:hover .qi-icon{
  background:linear-gradient(135deg,#c5293a,#7a1f2b);
  color:#fff;
}
.quick-item.siren-item .qi-label{
  color:#7a1f2b;
  font-weight:700;
}

/* SIREN 배지 */
.siren-badge{
  position:absolute;
  top:12px;
  left:50%;
  transform:translateX(-50%);
  background:linear-gradient(135deg,#c5293a,#7a1f2b);
  color:#fff;
  font-size:9.5px;
  font-weight:800;
  letter-spacing:1.2px;
  padding:3px 11px;
  border-radius:11px;
  font-family:'Inter',sans-serif;
  box-shadow:0 2px 8px rgba(197,41,58,0.35);
  animation:siren-badge-pulse 2.5s ease-in-out infinite;
  white-space:nowrap;
  z-index:3;
}
@keyframes siren-badge-pulse{
  0%,100%{transform:translateX(-50%) scale(1);box-shadow:0 2px 8px rgba(197,41,58,0.35);}
  50%{transform:translateX(-50%) scale(1.06);box-shadow:0 4px 14px rgba(197,41,58,0.55);}
}

/* SIREN 그룹의 qi-arrow는 배지와 겹치지 않게 위치 조정 */
.quick-item.siren-item .qi-arrow{
  top:12px;
  right:12px;
}

/* =========================================================
   STATS
   ========================================================= */
.stats{background:var(--ink);color:#fff;padding:80px 0;position:relative;overflow:hidden}
.stats::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 10%,var(--gold) 50%,transparent 90%);opacity:.6;
}
.stats-head{padding-bottom:30px;border-bottom:1px solid #1f1f1f;margin-bottom:50px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.stat{padding:0 24px;border-right:1px solid #1f1f1f;position:relative}
.stat:last-child{border-right:none}
.stat-num{
  font-family:'Noto Serif KR',serif;font-size:46px;font-weight:700;
  color:var(--gold);margin-bottom:6px;letter-spacing:-.03em;line-height:1;
}
.stat-num small{font-size:18px;margin-left:4px;color:#666;font-weight:400}
.stat-label{font-size:13px;color:#999;letter-spacing:.05em;font-weight:400}

/* =========================================================
   NOTICE + FAQ
   ========================================================= */
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.notice-list{border-top:1px solid var(--ink)}
.notice-list li{
  display:grid;
  grid-template-columns:74px 1fr 90px;
  align-items:center;
  gap:14px;
  padding:14px 6px;
  font-size:13.5px;
  border-bottom:1px solid var(--line);
  cursor:pointer;
  transition:all var(--t);
}
.notice-list li:hover{padding-left:14px;background:var(--bg-soft)}
.notice-list .tag{
  font-size:10.5px;
  padding:3px 8px;
  min-width:0;
  width:100%;
  text-align:center;
  letter-spacing:-.02em;
  white-space:nowrap;
}
.notice-list .notice-title{
  font-size:13.5px;
  font-weight:500;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  min-width:0;
  color:var(--text);
}
.notice-list .notice-date{
  font-size:11.5px;
  color:var(--text-3);
  text-align:right;
  white-space:nowrap;
  font-family:'Inter';
}

.faq-item{border-bottom:1px solid var(--line)}
.faq-item:first-child{border-top:1px solid var(--ink)}
.faq-q{
  display:flex;
  align-items:flex-start;
  padding:16px 6px;
  cursor:pointer;
  font-weight:500;
  font-size:13.5px;
  transition:color var(--t);
  gap:12px;
}
.faq-q:hover{color:var(--brand)}
.q-mark{color:var(--brand);font-family:'Noto Serif KR',serif;font-weight:700;font-size:16px;line-height:1;flex-shrink:0;margin-top:-1px}
.faq-q > span:nth-child(2){
  flex:1;
  line-height:1.5;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.faq-q .arrow{margin-left:auto;transition:transform var(--t);font-size:11px;color:var(--text-3);font-family:'Inter';flex-shrink:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a-inner{
  padding:6px 6px 18px 32px;
  font-size:12.5px;
  color:var(--text-2);
  line-height:1.75;
}
.faq-item.open .faq-a{max-height:300px}
.faq-item.open .arrow{transform:rotate(180deg);color:var(--brand)}
.faq-item.open .faq-q{color:var(--brand)}

/* 소식 페이지 테이블 */
table.tbl td:nth-child(3){
  max-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* =========================================================
   CAMPAIGN
   ========================================================= */
.campaign{
  background:linear-gradient(135deg,#141414 0%,#2a1119 60%,#141414 100%);
  color:#fff;border-radius:var(--radius-lg);padding:64px;
  display:grid;grid-template-columns:1.3fr 1fr;gap:50px;align-items:center;
  position:relative;overflow:hidden;
}
.campaign::before{
  content:"";position:absolute;right:-150px;top:-150px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(184,147,90,.18),transparent 65%);
}
.camp-tag{
  display:inline-block;padding:5px 12px;background:var(--gold);color:#1a1a1a;
  border-radius:3px;font-size:10.5px;font-weight:700;letter-spacing:.2em;margin-bottom:20px;font-family:'Inter';
}
.campaign h3{font-family:'Noto Serif KR',serif;font-size:30px;font-weight:600;margin-bottom:18px;line-height:1.45;letter-spacing:-.02em}
.campaign p.lead{color:#bbb;margin-bottom:32px;font-size:14.5px;line-height:1.85}
.progress{background:rgba(255,255,255,.08);height:8px;border-radius:4px;overflow:hidden;margin-bottom:14px}
.progress-bar{height:100%;background:linear-gradient(90deg,var(--brand),var(--gold));border-radius:4px;transition:width 1.2s ease}
.progress-stats{display:flex;justify-content:space-between;font-size:13px;color:#999;margin-bottom:32px;font-family:'Inter'}
.progress-stats strong{color:var(--gold);font-size:15px;font-family:'Noto Serif KR',serif;font-weight:700}
.camp-visual{position:relative;text-align:center;z-index:2}

/* =========================================================
   HOME RESPONSIVE
   ========================================================= */
@media (max-width:1100px){
  .quick-grid{grid-template-columns:repeat(3,1fr)}
  .quick-item:nth-child(3n){border-right:none}
  .quick-item:nth-child(-n+3){border-bottom:1px solid var(--line-soft)}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px 0}
  .stat:nth-child(2n){border-right:none}
  .info-grid{grid-template-columns:1fr;gap:50px}
  .campaign{grid-template-columns:1fr;padding:44px}
}
@media (max-width:980px){
  .hero{padding-top:60px}
  .hero h1{font-size:36px}
  .ribbon-art{width:260px;height:260px;opacity:.6}
}
@media (max-width:560px){
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .quick-item{border-right:none !important;border-bottom:1px solid var(--line-soft)}
  .quick-item.siren-item{padding-top:42px}
  .siren-badge{font-size:9px;padding:2px 9px;letter-spacing:1px}
  .notice-list li{grid-template-columns:60px 1fr 80px;gap:10px;font-size:12.5px}
  .notice-list .tag{font-size:10px;padding:2px 6px}
  .notice-list .notice-title{font-size:12.5px}
}