/* 아스테리아 디지털혁신부 — Ethereal Indigo theme */
* { box-sizing: border-box; }
:root {
  --gov-blue: #6366f1;          /* 인디고 (메인) */
  --gov-blue-dark: #2e2a72;     /* 딥 인디고 (제목/링크 강조) */
  --gov-gold: #e9d5ff;          /* 라벤더 펄 (액센트) */
  --gov-gold-deep: #c084fc;     /* 라벤더 강조 */
  --gov-gray: #585578;          /* 차분한 보라회색 */
  --gov-bg: #f5f3ff;            /* 라벤더 미스트 배경 */
  --gov-line: #ddd6fe;          /* 옅은 보라 라인 */
  --gov-mist: #ede9fe;
  --gov-ink: #1e1b4b;
  --shadow-soft: 0 10px 30px rgba(99,102,241,.12);
  --shadow-hover: 0 14px 36px rgba(99,102,241,.22);
}
html, body { min-height: 100%; }
body {
  font-family: "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Helvetica Neue", sans-serif;
  margin: 0;
  color: #2c2a4a;
  line-height: 1.55;
  background:
    radial-gradient(900px 500px at 5% -5%,  rgba(199,210,254,.55), transparent 60%),
    radial-gradient(900px 500px at 105% 110%, rgba(233,213,255,.55), transparent 60%),
    radial-gradient(600px 400px at 80% 0%,  rgba(165,180,252,.35), transparent 60%),
    var(--gov-bg);
  background-attachment: fixed;
}
a { color: var(--gov-blue); text-decoration: none; }
a:hover { text-decoration: underline; }
.container { max-width: 1180px; margin: 0 auto; padding: 0 16px; }

/* === Top utility bar === */
.utilbar {
  background: linear-gradient(90deg, #ede9fe 0%, #f5f3ff 50%, #fce7f3 100%);
  border-bottom: 1px solid var(--gov-line);
  font-size: 12px;
  color: var(--gov-gray);
}
.utilbar .container { display: flex; justify-content: flex-end; gap: 14px; padding: 6px 16px; }
.utilbar a { color: var(--gov-gray); }

/* === Main header === */
.gov-header {
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--gov-line);
  box-shadow: 0 6px 20px rgba(99,102,241,.06);
}
.gov-header .container { display: flex; align-items: center; gap: 18px; padding: 16px; }
.gov-header .brand { display: flex; align-items: center; gap: 12px; }
.gov-header .brand img { width: 56px; height: 56px; filter: drop-shadow(0 4px 10px rgba(124,58,237,.25)); }
.gov-header .brand-text .country { font-size: 12px; color: var(--gov-gold-deep); letter-spacing: 2px; }
.gov-header .brand-text .ministry { font-size: 22px; font-weight: 700; color: var(--gov-blue-dark); }
.gov-header .brand-text .en { font-size: 11px; color: #8a86b5; letter-spacing: .5px; }
.gov-header .gnb { margin-left: auto; display: flex; gap: 28px; }
.gov-header .gnb a {
  font-weight: 600; color: var(--gov-ink); font-size: 16px;
  padding: 8px 4px; border-bottom: 3px solid transparent;
  transition: color .15s, border-color .15s;
}
.gov-header .gnb a:hover, .gov-header .gnb a.active {
  border-bottom-color: var(--gov-gold-deep);
  text-decoration: none; color: var(--gov-blue-dark);
}

/* === Hero banner === */
.hero {
  position: relative;
  background-image:
    linear-gradient(135deg, rgba(46,42,114,.86) 0%, rgba(99,102,241,.70) 45%, rgba(192,132,252,.55) 100%),
    url('/assets/img/banner.jpg');
  background-size: cover; background-position: center;
  color: #fff; padding: 70px 0;
  overflow: hidden;
}
.hero::after {
  /* 별빛 같은 작은 점들 */
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(2px 2px at 12% 30%, #fff 50%, transparent 51%),
    radial-gradient(1.5px 1.5px at 78% 18%, #fff 50%, transparent 51%),
    radial-gradient(1px 1px at 35% 78%, #fff 50%, transparent 51%),
    radial-gradient(2px 2px at 92% 65%, #fff 50%, transparent 51%),
    radial-gradient(1px 1px at 55% 40%, #fff 50%, transparent 51%);
  opacity: .55;
}
.hero h1 { font-size: 34px; margin: 0 0 8px; letter-spacing: -.5px; text-shadow: 0 2px 14px rgba(0,0,0,.25); }
.hero p  { font-size: 15px; opacity: .92; margin: 0; }
.hero .searchbox { margin-top: 26px; max-width: 580px; display: flex; gap: 8px; position: relative; z-index: 1; }
.hero .searchbox input {
  flex: 1; padding: 13px 14px; border: 0; border-radius: 8px; font-size: 15px;
  background: rgba(255,255,255,.96); box-shadow: 0 6px 20px rgba(46,42,114,.25);
}
.hero .searchbox button {
  padding: 13px 24px;
  background: linear-gradient(135deg, #e9d5ff 0%, #fbcfe8 100%);
  color: var(--gov-ink); font-weight: 700; border: 0; border-radius: 8px;
  cursor: pointer; box-shadow: 0 6px 16px rgba(192,132,252,.4);
}

/* === Main content === */
main.container { padding: 30px 16px 60px; }
h1.page-title {
  font-size: 24px; color: var(--gov-blue-dark);
  border-bottom: 2px solid var(--gov-gold-deep);
  padding-bottom: 8px; margin: 0 0 20px;
}
.crumb { font-size: 13px; color: var(--gov-gray); margin-bottom: 14px; }
.crumb a { color: var(--gov-gray); }

/* === Card sections (home) === */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 18px; margin-top: 20px; }
.svc-card {
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(4px);
  border: 1px solid var(--gov-line);
  border-radius: 10px; padding: 18px;
  box-shadow: var(--shadow-soft);
  transition: transform .18s, box-shadow .18s;
}
.svc-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.svc-card a { color: inherit; }
.svc-card img { width: 100%; height: 140px; object-fit: cover; border-radius: 6px; filter: saturate(.92) hue-rotate(-8deg); }
.svc-card h3 { font-size: 17px; color: var(--gov-blue-dark); margin: 12px 0 6px; }
.svc-card p { color: var(--gov-gray); font-size: 14px; margin: 0; }
.svc-card a.more { display: inline-block; margin-top: 10px; font-size: 13px; color: var(--gov-blue); }

/* === Two-column home === */
.home-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; margin-top: 30px; }
.box {
  background: rgba(255,255,255,.86);
  border: 1px solid var(--gov-line);
  border-radius: 10px;
  padding: 18px 20px;
  box-shadow: var(--shadow-soft);
}
.box h2 { font-size: 18px; color: var(--gov-blue-dark); margin: 0 0 10px; display: flex; justify-content: space-between; align-items: baseline; }
.box h2 a { font-size: 12px; font-weight: 400; }
.notice-list { list-style: none; padding: 0; margin: 0; }
.notice-list li { padding: 10px 0; border-top: 1px solid var(--gov-line); display: flex; justify-content: space-between; gap: 10px; }
.notice-list li:first-child { border-top: 0; }
.notice-list .date { color: #9ca3af; font-size: 13px; flex-shrink: 0; }
.notice-list .tag {
  display:inline-block; padding: 1px 8px; border-radius: 999px; font-size: 11px; margin-right: 6px;
  background: linear-gradient(135deg, #e9d5ff, #ddd6fe); color: var(--gov-blue-dark);
}

/* === Board list === */
.board-tab { display: flex; gap: 0; border-bottom: 2px solid var(--gov-gold-deep); margin-bottom: 16px; }
.board-tab a {
  padding: 10px 22px; background: rgba(237,233,254,.55);
  border: 1px solid var(--gov-line); border-bottom: 0; color: var(--gov-gray);
  border-top-left-radius: 6px; border-top-right-radius: 6px;
}
.board-tab a.on {
  background: linear-gradient(135deg, var(--gov-blue-dark), var(--gov-blue));
  color: #fff; font-weight: 700;
}
.tbl { width: 100%; background: rgba(255,255,255,.88); border-collapse: collapse; border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-soft); }
.tbl th, .tbl td { padding: 12px 10px; border-bottom: 1px solid var(--gov-line); text-align: left; font-size: 14px; }
.tbl th { background: var(--gov-mist); color: var(--gov-blue-dark); font-weight: 700; border-top: 2px solid var(--gov-gold-deep); }
.tbl td.num, .tbl td.date, .tbl td.author { text-align: center; color: var(--gov-gray); white-space: nowrap; }
.tbl tr:hover td { background: rgba(237,233,254,.4); }
.lock-icon { color: var(--gov-gold-deep); margin-right: 4px; }
.pin-icon  { color: #db2777; font-weight: 700; margin-right: 4px; }
.atk-icon  { color: var(--gov-gray); margin-left: 4px; font-size: 12px; }
.pager { text-align: center; margin: 18px 0; display: flex; gap: 6px; justify-content: center; }
.pager a, .pager span { padding: 6px 12px; border: 1px solid var(--gov-line); border-radius: 4px; background: rgba(255,255,255,.7); }
.pager .on { background: linear-gradient(135deg, var(--gov-blue-dark), var(--gov-blue)); color: #fff; border-color: transparent; }
.actions { display: flex; justify-content: flex-end; gap: 8px; margin: 14px 0; }
.btn {
  padding: 9px 18px;
  background: linear-gradient(135deg, var(--gov-blue-dark) 0%, var(--gov-blue) 100%);
  color: #fff; border: 0; border-radius: 6px; font-size: 14px;
  cursor: pointer; text-decoration: none; display: inline-block;
  box-shadow: 0 4px 14px rgba(99,102,241,.3);
  transition: transform .15s, box-shadow .15s;
}
.btn:hover { transform: translateY(-1px); box-shadow: 0 6px 20px rgba(99,102,241,.4); text-decoration: none; }
.btn.alt { background: linear-gradient(135deg, #6b7280, #94a3b8); box-shadow: none; }
.btn.gold { background: linear-gradient(135deg, #e9d5ff, #c084fc); color: var(--gov-ink); }

/* === Post view === */
.post-view { background: rgba(255,255,255,.92); border: 1px solid var(--gov-line); border-radius: 10px; box-shadow: var(--shadow-soft); }
.post-view .post-head { padding: 22px 26px; border-bottom: 1px solid var(--gov-line); }
.post-view .post-head h1 { font-size: 22px; color: var(--gov-blue-dark); margin: 0 0 10px; }
.post-view .post-meta { color: var(--gov-gray); font-size: 13px; }
.post-view .post-meta span { margin-right: 14px; }
.post-view .post-body { padding: 30px 26px; min-height: 200px; white-space: pre-wrap; }
.post-view .post-files { border-top: 1px solid var(--gov-line); padding: 16px 26px; background: rgba(237,233,254,.35); border-bottom-left-radius: 10px; border-bottom-right-radius: 10px; }
.post-view .post-files h4 { margin: 0 0 8px; font-size: 14px; color: var(--gov-blue-dark); }
.post-view .post-files ul { list-style: none; padding: 0; margin: 0; }
.post-view .post-files li { padding: 4px 0; }

/* === Comments === */
.comments { margin-top: 28px; background: rgba(255,255,255,.9); border: 1px solid var(--gov-line); border-radius: 10px; padding: 18px 22px; box-shadow: var(--shadow-soft); }
.comments h3 { font-size: 16px; color: var(--gov-blue-dark); margin: 0 0 12px; }
.comment { padding: 10px 0; border-top: 1px solid var(--gov-line); }
.comment:first-of-type { border-top: 0; }
.comment .c-head { display:flex; gap:10px; font-size:13px; color: var(--gov-gray); margin-bottom: 4px; }
.comment .c-head .name { color: var(--gov-blue-dark); font-weight: 600; }
.comment-form { margin-top: 14px; display: flex; flex-direction: column; gap: 8px; }
.comment-form textarea { padding: 8px; border: 1px solid var(--gov-line); border-radius: 6px; min-height: 60px; background: rgba(255,255,255,.95); }

/* === Form === */
.form-card { max-width: 720px; background: rgba(255,255,255,.92); padding: 28px; border: 1px solid var(--gov-line); border-radius: 10px; box-shadow: var(--shadow-soft); }
.form-row { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; }
.form-row label { font-size: 14px; font-weight: 600; color: var(--gov-blue-dark); }
.form-row input, .form-row textarea, .form-row select {
  padding: 10px 12px; border: 1px solid var(--gov-line); border-radius: 6px; font-size: 14px;
  background: rgba(255,255,255,.96);
  transition: border-color .15s, box-shadow .15s;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
  outline: 0; border-color: var(--gov-blue); box-shadow: 0 0 0 3px rgba(99,102,241,.18);
}
.form-row textarea { min-height: 220px; }
.inline { display: flex; gap: 16px; align-items: center; }
.alert  { background: linear-gradient(135deg, #fce7f3, #fed7e2); color: #9d174d; padding: 10px 14px; border-radius: 6px; margin-bottom: 12px; }
.ok     { background: linear-gradient(135deg, #d1fae5, #e0f2fe); color: #065f46; padding: 10px 14px; border-radius: 6px; margin-bottom: 12px; }
.info   { background: linear-gradient(135deg, #ede9fe, #e0e7ff); color: var(--gov-blue-dark); padding: 10px 14px; border-radius: 6px; margin-bottom: 12px; font-size: 13px; }

/* === Admin === */
.stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px,1fr)); gap: 14px; margin-bottom: 20px; }
.stat { background: rgba(255,255,255,.92); border: 1px solid var(--gov-line); border-radius: 10px; padding: 18px; text-align: center; box-shadow: var(--shadow-soft); }
.stat h3 { margin: 0 0 4px; color: var(--gov-gray); font-size: 12px; font-weight: 600; }
.stat p { margin: 0; font-size: 24px; font-weight: 700;
  background: linear-gradient(135deg, var(--gov-blue-dark), var(--gov-gold-deep));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.mono { font-family: ui-monospace, Menlo, monospace; color: #be185d; font-size: 13px; }

/* === Footer === */
.gov-footer {
  background: linear-gradient(135deg, #1e1b4b 0%, #2e1065 100%);
  color: #c7c5e0; margin-top: 50px; padding: 30px 0; font-size: 13px;
}
.gov-footer .container { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
.gov-footer .ft-left strong { display: block; color: #fff; font-size: 14px; margin-bottom: 6px; }
.gov-footer a { color: #c4b5fd; }

/* === Debug / hint blocks === */
.dbg-error { background: #fce7f3; color: #9d174d; padding: 10px; border-radius: 4px; font-family: monospace; font-size: 13px; margin: 10px 0; }
.pagebox { background: var(--gov-ink); color: #f9fafb; padding: 16px; border-radius: 6px; overflow: auto; }
.badge-admin   { background: linear-gradient(135deg, #db2777, #e11d48); color: #fff; padding: 2px 8px; border-radius: 999px; font-size: 11px; }
.badge-officer { background: linear-gradient(135deg, var(--gov-blue-dark), var(--gov-blue)); color: #fff; padding: 2px 8px; border-radius: 999px; font-size: 11px; }
.search-echo { background: linear-gradient(135deg, #fef3c7, #fde68a); border-left: 4px solid var(--gov-gold-deep); padding: 8px 14px; margin: 12px 0; border-radius: 4px; }
