/* ===== 공통 CSS (모든 페이지 공유) ===== */
*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --navy:#1d3461;--red:#c8102e;--bg:#f4f7fc;
  --white:#fff;--border:#dde3ed;--text:#1a1a1a;--muted:#5a6474;
  --max:1440px;
}
html{font-size:16px;}
body{font-family:'Malgun Gothic','맑은 고딕',sans-serif;color:var(--text);background:var(--white);}
a{text-decoration:none;color:inherit;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px;}

/* ── 정부 최상단 바 (34px) ── */
.govbar{height:34px;background:#f7f9fc;border-bottom:1px solid #dde3ed;display:flex;align-items:center;}
.govbar-inner{max-width:var(--max);margin:0 auto;padding:0 28px;width:100%;display:flex;align-items:center;justify-content:space-between;}
.govbar-left{display:flex;align-items:center;gap:7px;font-size:13px;color:#555;}
.taeguk{display:inline-flex;width:18px;height:18px;border-radius:50%;background:conic-gradient(#c8102e 0deg 180deg,#003087 180deg 360deg);border:1px solid #ccc;flex-shrink:0;}
.govbar-right{display:flex;gap:18px;font-size:13px;}
.govbar-right a{color:#555;}
.govbar-right a:hover{color:var(--navy);text-decoration:underline;}
.govbar-right span{color:#ccc;}

/* ── 헤더 (80px) ── */
header{height:80px;background:var(--white);border-bottom:3px solid var(--navy);display:flex;align-items:center;}
.header-inner{max-width:var(--max);margin:0 auto;padding:0 28px;width:100%;display:flex;align-items:center;gap:24px;}
.h-logo{display:flex;align-items:center;gap:12px;flex-shrink:0;cursor:pointer;text-decoration:none;min-width:220px;}
.h-logo-mark{width:52px;height:52px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.h-logo-mark svg{width:32px;height:32px;}
.h-logo-texts strong{display:block;font-size:21px;font-weight:900;color:var(--navy);letter-spacing:-0.5px;white-space:nowrap;}
.h-logo-texts span{font-size:12px;color:var(--muted);white-space:nowrap;}
/* 중앙 검색창 */
.h-search-center{display:none;}
.h-search-center input{flex:1;border:none;padding:10px 14px;font-size:15px;font-family:inherit;outline:none;min-width:0;}
.h-search-center button{background:var(--navy);color:#fff;border:none;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;flex-shrink:0;}
.h-search-center button:hover{background:#2a4a80;}
/* 우측 유저 영역 */
.h-userinfo{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:auto;justify-content:flex-end;}
.h-username{font-size:15px;font-weight:700;color:var(--navy);white-space:nowrap;}
.btn-logout{background:#fff;color:var(--navy);border:2px solid var(--navy);padding:7px 16px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;}
.btn-logout:hover{background:#eef2fb;}
.btn-login-h{background:var(--navy);color:#fff;border:none;padding:8px 18px;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;}
.btn-login-h:hover{background:#2a4a80;}
.btn-join{background:#fff;color:var(--navy);border:2px solid var(--navy);padding:7px 14px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;}
.btn-join:hover{background:#eef2fb;}
/* 구버전 h-gnb / h-util / h-search 호환 유지 */
.h-gnb{display:none;}
.h-util{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.h-search{display:flex;border:2px solid var(--navy);overflow:hidden;}
.h-search input{border:none;padding:8px 13px;font-size:15px;font-family:inherit;outline:none;width:190px;}
.h-search button{background:var(--navy);color:#fff;border:none;padding:8px 16px;font-size:14px;cursor:pointer;font-family:inherit;font-weight:600;}

/* ── 주메뉴 (50px) ── */
.main-nav{height:50px;background:var(--navy);border-bottom:3px solid var(--red);display:flex;align-items:center;}
.main-nav-inner{max-width:var(--max);margin:0 auto;padding:0 28px;display:flex;width:100%;height:100%;}
.nav-item{flex:1;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:rgba(255,255,255,.85);text-decoration:none;border-right:1px solid rgba(255,255,255,.12);transition:background .15s;white-space:nowrap;}
.nav-item:last-child{border-right:none;}
.nav-item:hover,.nav-item.on{background:rgba(255,255,255,.15);color:#fff;}

/* ── 페이지 히어로 ── */
.page-hero{background:var(--navy);color:#fff;padding:22px 0;}
.page-hero .page-hero-inner{max-width:var(--max);margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.page-hero h1{font-size:24px;font-weight:900;margin-bottom:4px;}
.page-hero p{font-size:14px;opacity:.75;}
.page-hero-meta{display:flex;gap:14px;font-size:14px;opacity:.85;flex-shrink:0;}

/* ── 페이지 타이틀 바 ── */
.ptbar{background:#fff;border-bottom:1px solid var(--border);padding:10px 28px;}
.ptbar-inner{max-width:var(--max);margin:0 auto;font-size:13px;color:#888;}
.ptbar-inner a{color:var(--navy);}
.ptbar-inner .curr{color:#333;font-weight:600;}

/* ── 긴급 띠 ── */
.emg-strip{background:var(--red);color:#fff;padding:10px 0;font-size:14px;font-weight:600;}
.emg-strip .wrap{display:flex;align-items:center;gap:12px;}
.emg-tag{background:#fff;color:var(--red);font-size:12px;font-weight:900;padding:2px 10px;flex-shrink:0;}
.emg-x{margin-left:auto;background:none;border:none;color:#fff;font-size:20px;cursor:pointer;opacity:.8;}

/* ── 섹션 타이틀 ── */
.sec-ttl{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:8px;}
.sec-ttl::before{content:'';width:4px;height:22px;background:var(--red);display:inline-block;flex-shrink:0;}

/* ── 카드 ── */
.card{background:#fff;border:1px solid var(--border);}
.card-top{background:#fff;border-bottom:1px solid var(--border);padding:11px 16px;font-size:15px;font-weight:700;color:var(--navy);display:flex;align-items:center;justify-content:space-between;}
.card-top-navy{background:var(--navy);color:#fff;border-bottom:none;}
.card-top-navy a{color:rgba(255,255,255,.65);font-size:13px;font-weight:400;}
.card-top-navy a:hover{color:#fff;}
.card-body{padding:16px;}

/* ── 버튼 ── */
.btn-primary{background:var(--navy);color:#fff;border:none;padding:10px 22px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;}
.btn-primary:hover{background:#2a4a80;}
.btn-secondary{background:#fff;color:var(--navy);border:2px solid var(--navy);padding:9px 20px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;}
.btn-secondary:hover{background:#eef2fb;}
.btn-red{background:var(--red);color:#fff;border:none;padding:9px 20px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;}
.btn-red:hover{background:#a30d26;}
.btn-sm{padding:5px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;border:none;}
.btn-sm-out{padding:5px 13px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}

/* ── 폼 ── */
.form-row{margin-bottom:14px;}
.form-row label{display:block;font-size:14px;font-weight:600;color:#444;margin-bottom:6px;}
.form-row .req{color:var(--red);margin-left:2px;}
.form-row input,.form-row select,.form-row textarea{width:100%;border:1px solid #ccc;padding:10px 12px;font-size:15px;font-family:inherit;outline:none;color:var(--text);transition:border-color .2s;}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--navy);}
.form-row .hint{font-size:12px;color:#aaa;margin-top:4px;}

/* ── 모달 ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:999;align-items:center;justify-content:center;}
.modal-bg.open{display:flex;}
.modal{background:#fff;border-top:4px solid var(--navy);max-height:92vh;overflow-y:auto;}
.modal-head{padding:16px 20px;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff;z-index:1;}
.modal-head h3{font-size:18px;font-weight:700;color:var(--navy);}
.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:#888;}
.modal-body{padding:20px;}
.modal-foot{padding:14px 20px;border-top:1px solid #eee;display:flex;justify-content:flex-end;gap:8px;position:sticky;bottom:0;background:#fff;}

/* ── 테이블 ── */
.tbl-wrap{background:#fff;border:1px solid var(--border);overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead tr{background:var(--navy);color:#fff;}
thead th{padding:12px 14px;font-size:14px;font-weight:600;text-align:left;white-space:nowrap;}
tbody tr{border-bottom:1px solid #f0f4fa;transition:background .1s;}
tbody tr:hover{background:#f8faff;}
tbody td{padding:11px 14px;font-size:15px;}

/* ── 푸터 ── */
footer{background:#1a2a4a;color:rgba(255,255,255,.65);padding:20px 0;font-size:14px;}
footer .wrap{display:flex;justify-content:space-between;align-items:center;}
.ft-links{display:flex;gap:18px;}
.ft-links a{color:rgba(255,255,255,.55);}
.ft-links a:hover{color:#fff;}

/* ── 로그인 모달 ── */
.login-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;}
.login-modal-bg.open{display:flex;}
.login-modal{background:#fff;border-radius:16px;box-shadow:0 8px 40px rgba(0,0,0,.18);padding:28px 26px 22px;border:1px solid #eef0f6;width:420px;max-width:95vw;}
.login-modal .lc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;}
.login-modal .lc-top h2{font-size:24px;font-weight:900;color:#1a1a1a;letter-spacing:-.5px;}
.login-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#888;padding:0;}
.login-modal .lc-methods{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.login-modal .lc-method{display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 8px 14px;border-radius:12px;cursor:pointer;transition:background .15s;border:1.5px solid transparent;}
.login-modal .lc-method:hover{background:#f5f7ff;border-color:#d0d8f0;}
.login-modal .lc-icon-box{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;position:relative;}
.login-modal .icon-cert{background:linear-gradient(135deg,#ff7eb3 0%,#ff4e7e 100%);}
.login-modal .icon-cert::before{content:'';position:absolute;width:36px;height:28px;background:rgba(255,255,255,.25);border-radius:6px;top:12px;left:14px;}
.login-modal .icon-cert::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#ff2255;border:3px solid #fff;bottom:8px;right:8px;}
.login-modal .icon-simple{background:linear-gradient(135deg,#a78bfa 0%,#6366f1 100%);}
.login-modal .icon-simple::before{content:'';position:absolute;width:30px;height:42px;background:rgba(255,255,255,.2);border-radius:8px;top:11px;left:17px;}
.login-modal .icon-simple::after{content:'🔍';position:absolute;font-size:20px;bottom:6px;right:5px;}
.login-modal .icon-id{background:linear-gradient(135deg,#38bdf8 0%,#1d4ed8 100%);}
.login-modal .icon-id::before{content:'';position:absolute;width:38px;height:26px;background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.5);border-radius:4px;top:14px;left:13px;}
.login-modal .icon-id::after{content:'⏻';position:absolute;font-size:16px;color:#fff;bottom:8px;right:8px;}
.login-modal .lc-method-name{font-size:14px;font-weight:600;color:#333;text-align:center;line-height:1.3;}
.login-modal .lc-id-form{display:none;padding:0 0 4px;}
.login-modal .lc-id-form.show{display:block;}
.login-modal .btn-back-login{background:none;border:none;color:#888;font-size:13px;cursor:pointer;font-family:inherit;padding:0 0 12px;display:flex;align-items:center;gap:4px;}
.login-modal .btn-back-login:hover{color:var(--navy);}
.login-modal .lf-row{margin-bottom:10px;}
.login-modal .lf-row input{width:100%;border:1px solid #d0d5e0;padding:11px 13px;font-size:15px;font-family:inherit;outline:none;border-radius:6px;transition:border-color .2s;}
.login-modal .lf-row input:focus{border-color:var(--navy);}
.login-modal .lf-err{background:#fff0f0;border:1px solid #fcc;color:var(--red);font-size:13px;padding:8px 12px;margin-bottom:10px;border-radius:6px;display:none;}
.login-modal .lf-err.show{display:block;}
.login-modal .btn-lc-do{width:100%;background:var(--navy);color:#fff;border:none;padding:12px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;border-radius:6px;margin-top:4px;}
.login-modal .btn-lc-do:hover{background:#2a4a80;}
.login-modal .lc-id-links{display:flex;justify-content:center;gap:16px;margin-top:10px;font-size:13px;}
.login-modal .lc-id-links a{color:#888;}
.login-modal .lc-switch-wrap{min-height:200px;margin-bottom:14px;display:flex;flex-direction:column;justify-content:center;}
.login-modal .btn-other-login{width:100%;background:#f5f7ff;color:var(--navy);border:1.5px solid #c8d0e8;padding:12px;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;border-radius:8px;transition:all .15s;}
.login-modal .btn-other-login:hover{background:#eef2fb;border-color:var(--navy);}

@media(max-width:900px){.h-logo-texts span{display:none;}.h-search-center{margin:0;max-width:none;}}
@media(max-width:640px){.h-search-center button span{display:none;}.wrap{padding:0 14px;}.govbar-inner{padding:0 14px;}.main-nav-inner{padding:0 14px;}.header-inner{gap:12px;padding:0 14px;}.h-userinfo{min-width:auto;}}
