:root{
    --primary:#69bf11;
    --primary-dark:#4c980a;
    --primary-soft:#eff9e5;
    --lookup-bg:#eef6ff;
    --lookup-border:#cfe3ff;
    --lookup-text:#2557a7;
    --text:#1f2937;
    --muted:#6b7280;
    --line:#e5e7eb;
    --bg:#f5f7fb;
    --card:#ffffff;
    --danger:#dc2626;
    --shadow:0 12px 32px rgba(17,24,39,.08);
    --shadow-soft:0 8px 24px rgba(17,24,39,.06);
    --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:'Pretendard','Malgun Gothic',sans-serif;color:var(--text);background:linear-gradient(180deg,#f7f9fc 0%, #f3f6fa 100%)}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
.wrap{max-width:860px;margin:0 auto;padding:18px 16px 24px}
.site-header{max-width:860px;margin:0 auto;padding:0 16px}
.site-logo{width:100%;border-radius:0 0 16px 16px;box-shadow:var(--shadow)}
.site-footer{padding:24px 0 32px;text-align:center;color:var(--muted);font-size:14px}

.card{
    background:var(--card);
    border-radius:22px;
    box-shadow:var(--shadow);
    padding:24px;
    border:1px solid rgba(229,231,235,.9);
}
.card + .card{margin-top:16px}

.hero-card{
    padding:22px 24px;
    background:linear-gradient(180deg,#ffffff 0%, #fbfcfe 100%);
}
.hero-top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:14px;
}

.form-card{
    padding-top:24px;
}

.page-title{font-size:28px;line-height:1.2;margin:8px 0 8px;font-weight:800;letter-spacing:-0.02em}
.page-desc{font-size:15px;color:var(--muted);line-height:1.65;margin:0}
.section-title{font-size:18px;font-weight:800;margin:0 0 14px;letter-spacing:-0.01em}
.section-gap{margin-top:28px}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.one{grid-template-columns:1fr}

.field{display:flex;flex-direction:column;gap:8px}
.field label{font-weight:700;font-size:14px;line-height:1.5}
.req{color:var(--danger);margin-left:4px}

.input,.select,.textarea{
    width:100%;
    min-height:50px;
    padding:13px 15px;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    outline:none;
    transition:.2s;
}
.input:hover,.select:hover,.textarea:hover{border-color:#cfd8e3}
.input:focus,.select:focus,.textarea:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(105,191,17,.12);
}
.textarea{min-height:110px;resize:vertical}
.help{font-size:12px;color:var(--muted);line-height:1.5}

.btn-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.btn-row.center{justify-content:center}
.btn-row.right{justify-content:flex-end}

.btn{
    appearance:none;
    border:none;
    border-radius:14px;
    padding:14px 18px;
    font-weight:800;
    cursor:pointer;
    transition:.2s;
    min-height:48px;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 8px 18px rgba(105,191,17,.22)}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:#eef2f7;color:var(--text)}
.btn-outline{background:#fff;border:1px solid var(--line)}

.btn-lookup{
    min-height:40px;
    padding:10px 14px;
    border-radius:12px;
    background:var(--lookup-bg);
    border:1px solid var(--lookup-border);
    color:var(--lookup-text);
    font-size:13px;
    font-weight:800;
    box-shadow:none;
}
.btn-lookup:hover{
    background:#e3f0ff;
    border-color:#bdd7ff;
}
.lookup-row{margin-top:0}
.btn-submit{min-width:180px}

.check-group,.radio-group{display:flex;flex-wrap:wrap;gap:10px}
.check-group.vertical,.radio-group.vertical{
    flex-direction:column;
    gap:10px;
}
.check-chip,.radio-chip{
    display:flex;
    align-items:center;
    gap:10px;
    width:100%;
    padding:14px 16px;
    border:1px solid var(--line);
    border-radius:14px;
    background:#fff;
    font-size:14px;
    line-height:1.5;
    box-shadow:var(--shadow-soft);
    transition:.2s;
}
.check-chip:hover,.radio-chip:hover{
    border-color:#cfd8e3;
    transform:translateY(-1px);
}
.check-chip input,.radio-chip input{
    flex:0 0 auto;
}

.survey-list{
    display:flex;
    flex-direction:column;
    gap:14px;
}
.survey-item{
    padding:16px;
    border:1px solid #edf0f4;
    border-radius:18px;
    background:#fcfdff;
}

.notice-box{
    padding:14px 16px;
    background:#f9fafb;
    border:1px solid var(--line);
    border-radius:14px;
    color:var(--muted);
    font-size:14px;
    line-height:1.65
}

.result-box{text-align:center}
.result-name{font-size:24px;font-weight:900;margin:6px 0}
.result-code{font-size:30px;font-weight:900;color:var(--primary-dark);letter-spacing:1px;margin:12px 0}
.qr-wrap{display:flex;justify-content:center;margin:18px 0}

.marquee{overflow:hidden;white-space:nowrap;border-radius:999px;background:#111827;color:#fff;padding:10px 0}
.marquee span{display:inline-block;padding-left:100%;animation:marquee 12s linear infinite;font-weight:700}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}

.top-actions{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px;background:#fff}
.table{width:100%;border-collapse:collapse;min-width:900px}
.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--line);font-size:14px;text-align:left;vertical-align:middle}
.table th{background:#f8fafc;font-weight:800}
.search-bar{display:grid;grid-template-columns:140px 1fr auto auto;gap:10px}
.pager{display:flex;gap:8px;justify-content:center;align-items:center;padding-top:16px;flex-wrap:wrap}
.pager a,.pager strong{min-width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line)}
.pager strong{background:var(--primary);color:#fff;border-color:var(--primary)}
.login-box{max-width:460px;margin:40px auto}
.badge{
    display:inline-block;
    padding:6px 11px;
    border-radius:999px;
    background:var(--primary-soft);
    color:var(--primary-dark);
    font-size:12px;
    font-weight:800;
}
.popup-body{background:#fff;padding:16px}
.inline{display:flex;gap:10px;align-items:center}
.hidden{display:none !important}

.agree-box{
    padding:18px 18px;
    background:#f9fafb;
    border:1px solid var(--line);
    border-radius:16px;
    color:var(--muted);
    font-size:14px;
    line-height:1.75;
}
.agree-text{
    margin-bottom:12px;
    color:var(--text);
    line-height:1.8;
}
.agree-check{
    display:flex;
    align-items:flex-start;
    gap:8px;
    color:var(--text);
    font-weight:700;
}
.agree-check input{
    margin-top:3px;
    flex:0 0 auto;
}

.submit-row{
    margin-top:26px;
}

.modal-open{overflow:hidden}
.modal-dim{
    position:fixed;
    inset:0;
    background:rgba(17,24,39,.58);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    z-index:9999
}
.modal-card{
    width:100%;
    max-width:360px;
    background:#fff;
    border-radius:20px;
    box-shadow:0 20px 60px rgba(17,24,39,.25);
    padding:22px 18px;
    text-align:center
}
.modal-title{font-size:20px;font-weight:900;margin:0 0 10px}
.modal-text{font-size:15px;line-height:1.65;color:var(--text);margin:0 0 18px;word-break:keep-all}
.modal-actions{display:flex;justify-content:center}
.modal-actions .btn{width:auto;min-width:120px}

@media (max-width:768px){
    .wrap{padding:12px}
    .site-header{padding:0 12px}
    .card{padding:18px}
    .hero-card{padding:18px}
    .hero-top{flex-direction:column;align-items:stretch}
    .page-title{font-size:22px}
    .form-grid,.search-bar{grid-template-columns:1fr}
    .btn{width:100%}
    .btn-row.right .btn-lookup{width:auto;align-self:flex-end}
    .top-actions{flex-direction:column;align-items:stretch}
    .survey-item{padding:14px}
    .modal-card{max-width:100%;padding:20px 16px}
}