@charset "utf-8";

:root {
    --color-primary: #3e2b6b;
    --color-accent: #f77e0b;
    --color-text-main: #232b36;
    --color-text-sub: #333a45;
    --color-surface-muted: #f0eef3;
    --color-border-soft: #e2e2e8;
    --radius-lg: 24px;
    --radius-md: 16px;
    --space-section-y: 80px;
}

/* 내용관리 */
#header {background:#ffffff}
#header #logo a {background-image:url("../../../img/logo-b.svg");}
#header .gnb a {color:var(--color-text-main)}
#header .header-button a {color:var(--color-text-main)}

#ctt {margin:0;padding:100px 0 0 0; font-size:1rem; line-height:160%}
#ctt p {padding:2px 0; line-height:160%; word-break:keep-all}

.ctt_admin {text-align: right; top: 100px; position: absolute;right: 0; display: inline-block; border: 1px solid #ccc; background: #fff;padding: 0 13px;font-weight: 500; text-decoration: none; vertical-align: middle;}
.ctt_admin a { font-size:12px; color:#333}
#ctt header h1 {position:absolute;font-size:0;line-height:0;overflow:hidden}
#ctt_con {padding:0;line-height:1.6em; width:100%; margin:0 auto 100px;}
#ctt_con img{max-width:100%;height:auto}
.ctt_img {text-align:center}
.inner {width:90%; max-width:1640px; margin:0 auto;}
.section-pa {padding:var(--space-section-y) 0;}
.section-ma {margin:40px 0;}
.section-flex {display:flex; justify-content:space-between; align-items:center;}
.flex-half {flex:0 0 50%;padding:24px;}
.memberWrap {max-width:1240px;margin:0 auto;text-align:left;padding:150px 10px 50px 10px;color:#666; letter-spacing:-0.8px;line-height:24px;word-break:keep-all}
.memberWrap h3{font-size:18px;font-weight:500;color:#333;margin-bottom:10px;margin-top:50px; }
.memberWrap h3:first-child{margin-top:0}
.memberWrap p{margin-top:15px; line-height:1.6;word-break:keep-all; font-size:15px}
.memberWrap .law{margin-top:15px;padding:20px;border:solid 1px #ebebeb;background:#fafafa; font-size:14px}
.memberWrap .law ul li{margin-top:3px; padding:0; line-height:1.6;}
.memberWrap .law ul li:first-child{margin-top:0}

.ready-wrap {padding: 8% 0;text-align:center;}
.ready-wrap h2 {font-size:2rem; font-weight:bold;}
.ready-wrap p {font-size:1.2rem; line-height:1.6; margin-top:16px;}
.ready-wrap .icon-wrap {font-size:4rem;padding:0 0 48px 0; color:var(--color-accent)}
.gubun-wrap {height:80%; min-height:100px}

@media (max-width: 1300px) {
    .item-wrap small {font-size: 1.2rem;}
}

@media (max-width: 1200px) {
    .section-flex {flex-wrap: wrap;}
    .item-wrap {padding:4% 0; flex:1 1 45%; border-bottom:1px solid #dfdfdf}
    .item-wrap .icon-wrap {right:0}

    .gubun-wrap {display:none;}
}

@media (max-width: 768px) {
    #ctt_con {
        margin: 0 auto 72px;
    }
}

@media (max-width: 500px) {
    #ctt_con {
        margin: 0 auto 52px;
    }
}

/* 서브 공통 타이틀 */
.sub-title-wrap {
    margin: 0;
}

.sub-title-wrap .sub-title {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.8px;
    color: var(--color-text-main);
}

.sub-title-wrap .sub-title-en {
    margin: 8px 0 0;
    font-size: 1.1rem;
    line-height: 1.4;
    letter-spacing: -0.02em;
    color: var(--color-primary);
    font-weight: 400;
}
.title-purple-box {display:inline-block; min-width:250px; width:auto; background:var(--color-primary); color:#ffffff; border-radius: 20px; font-size:1.2rem; margin:80px 0 24px 0; padding:12px 100px 12px 16px; font-weight:400; position:relative;}
.title-purple-box .icon-title-front {display:inline-block; vertical-align: middle;}
.title-purple-box .icon-title-after {position:absolute; right:16px;display:inline-block;font-size:1.2rem; top:52%; transform:translateY(-50%)}

.table-list {width:100%;}
.table-list table {width:100%; border-spacing: 0; border-collapse: collapse; table-layout: fixed;}
.table-list thead th {background:var(--color-surface-muted);border-right:1px solid #dfdfdf;; font-weight:600; padding:12px 16px; border-bottom:1px solid var(--color-border-soft); border-top:1px solid var(--color-primary); border-bottom:1px solid var(--color-primary); color:var(--color-text-main); }
.table-list thead th:last-child {border-right:none;}
.table-list tbody td, .table-list tbody th {background:#fff; border-right:1px solid #efefef; padding:24px; color:var(--color-text-main);}

.table-list tbody tr td.border-none {border-right:none;}
.table-list tbody tr:nth-child(even) td, .table-list tbody tr:nth-child(even) th {background:#f6f6f6;}
.ac { text-align:center;}

.tabs {display:block;padding:48px 0;}
.tabs .tab {display:inline-block; margin:4px 4px 4px 0;}
.tabs .tab a {font-size:1.2rem; padding:12px 24px;display:block;background:#fff;border-radius: var(--radius-md); color:var(--color-text-main);}
.tabs .tab.on a {background:var(--color-primary); color:#fff;}
p {font-size:1.4rem; line-height:1.7; color:var(--color-text-sub);}
.box1 {border-radius: var(--radius-lg); display:block; padding:48px; margin:16px 0;}
.box1 .icon, .box-basic .icon {color:var(--color-accent); padding-bottom:48px; font-size:2.2rem;}
.box1 h5 {color:var(--color-primary); font-weight:700; font-size:2rem; padding-bottom:18px;}
.box1 p {font-size:1.3rem; font-weight:400; line-height:1.75; color:var(--color-text-sub);}
.box1 strong {font-weight:700;}
.bg-light {background:#F3F2F6}
.box-basic { padding:24px 0}
.box-basic h5 {color:var(--color-primary); font-weight:700; font-size:1.8rem; padding-bottom:24px;}
.box-basic p {font-size:1.2rem;}
.gubun {height:1px; background:#dfdfdf; margin:24px 0;width:100%; overflow:hidden; padding:0}
h5 {color:var(--color-primary); font-weight:700; font-size:2rem; padding-bottom:24px;}
h5 span {display:inline-block;}
.txt-yellow {color:var(--color-accent)}

/* 공통 UI 모바일 최적화 (48-101 구간 대응) */
@media (max-width: 1024px) {
    .sub-title-wrap .sub-title {
        font-size: 2.05rem;
        line-height: 1.35;
    }

    .sub-title-wrap .sub-title-en {
        font-size: 1rem;
    }

    .title-purple-box {
        margin: 56px 0 20px;
        font-size: 1.08rem;
        padding: 11px 72px 11px 14px;
    }

    .table-list thead th,
    .table-list tbody td,
    .table-list tbody th {
        font-size: 0.95rem;
        padding: 12px 14px;
    }

    .tabs {
        padding: 32px 0;
    }

    .tabs .tab a {
        font-size: 1.05rem;
        padding: 10px 18px;
    }

    p {
        font-size: 1.15rem;
        line-height: 1.7;
    }

    .box1 {
        padding: 34px 30px;
    }

    .box1 h5,
    h5 {
        font-size: 1.7rem;
    }
}

@media (max-width: 768px) {
    .sub-title-wrap .sub-title {
        font-size: 1.75rem;
        line-height: 1.4;
        letter-spacing: -0.03em;
        word-break: keep-all;
    }

    .sub-title-wrap .sub-title-en {
        margin-top: 6px;
        font-size: 0.92rem;
    }

    .title-purple-box {
        min-width: 0;
        margin: 36px 0 14px;
        font-size: 0.98rem;
        border-radius: 14px;
        padding: 10px 46px 10px 12px;
    }

    .title-purple-box .icon-title-after {
        right: 12px;
        font-size: 0.95rem;
    }

    .table-list {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    /*
    .table-list table {
        min-width: 680px;
    }*/

    .table-list thead th,
    .table-list tbody td,
    .table-list tbody th {
        font-size: 0.9rem;
        padding: 10px 10px;
    }

    .tabs {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 6px;
        padding: 22px 0;
    }

    .tabs .tab {
        margin: 0;
    }

    .tabs .tab a {
        font-size: 0.95rem;
        padding: 9px 12px;
        border-radius: 12px;
    }

    p {
        font-size: 0.98rem;
        line-height: 1.7;
    }

    .box1 {
        border-radius: 16px;
        padding: 22px 16px;
    }

    .box1 .icon,
    .box-basic .icon {
        font-size: 1.65rem;
        padding-bottom: 20px;
    }

    .box1 h5,
    h5 {
        font-size: 1.35rem;
        padding-bottom: 10px;
    }

    .box1 p,
    .box-basic p {
        font-size: 0.92rem;
        line-height: 1.65;
    }

    .box-basic {
        padding: 14px 0;
    }
}

@media (max-width: 500px) {
    .sub-title-wrap .sub-title {
        font-size: 1.45rem;
    }

    .sub-title-wrap .sub-title-en {
        font-size: 0.86rem;
    }

    .title-purple-box {
        font-size: 0.92rem;
        padding-right: 42px;
    }
    /*
    .table-list table {
        min-width: 560px;
    }*/

    .table-list thead th,
    .table-list tbody td,
    .table-list tbody th {
        font-size: 0.84rem;
        padding: 9px 8px;
    }

    .tabs .tab a {
        font-size: 0.9rem;
        padding: 8px 11px;
    }

    .box1 {
        padding: 18px 13px;
    }
}



/* 산후조리원 소개 */
.postpartum-wrap {
    margin: 0 auto;
    padding: 50px 0;
}

.postpartum-wrap .postpartum-greeting {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 48px;
}

.postpartum-wrap .postpartum-copy {
    flex: 0 0 40%;
    color: #232b36;
    word-break: keep-all;
}

.postpartum-wrap .postpartum-text {
    font-size: 1.1rem;
    font-weight:300;
    line-height: 1.75;
    letter-spacing: -0.02em;
    color: #333a45;
}

.postpartum-wrap .postpartum-text + .postpartum-text {
    margin-top: 28px;
}

.postpartum-wrap .postpartum-media {
    flex: 0 0 50%;
    border-radius: 16px;
    overflow: hidden;
    background: #ddd;
}

.postpartum-wrap .postpartum-media img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.postpartum-wrap .postpartum-point-list {
    margin-top: 56px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 36px;
}

.postpartum-wrap .postpartum-point-item {
    flex: 1 1 0;
    text-align: center;
    color: #232b36;
}

.postpartum-wrap .postpartum-point-thumb {
    border-radius: 16px;
    overflow: hidden;
    background: #ddd;
}

.postpartum-wrap .postpartum-point-thumb img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.postpartum-wrap .postpartum-point-title {
    margin: 16px 0 10px;
    font-size: 2rem;
    line-height: 1.3;
    font-weight: 700;
    color: #3e2b6b;
    letter-spacing: -0.03em;
}

@media (max-width: 1300px) {
    .sub-title-wrap .sub-title {
        font-size: 2.1rem;
    }

    .sub-title-wrap .sub-title-en,
    .postpartum-wrap .postpartum-text {
        font-size: 1.05rem;
    }

    .postpartum-wrap .postpartum-point-title {
        font-size: 1.6rem;
    }
}

.postpartum-wrap .postpartum-point-desc {
    margin: 0;
    font-size: 18px;
    line-height: 1.6;
    font-weight: 400;
    color: #333a45;
    letter-spacing: -0.02em;
}

@media (max-width: 960px) {
    .postpartum-wrap {
        padding: 50px 16px 40px;
    }

    .postpartum-wrap .postpartum-greeting {
        flex-direction: column;
        align-items: flex-start;
        gap: 30px;
    }

    .postpartum-wrap .postpartum-copy,
    .postpartum-wrap .postpartum-media {
        flex: none;
        width: 100%;
    }

    .postpartum-wrap .postpartum-text {
        margin-top: 24px;
        line-height: 1.7;
    }

    .postpartum-wrap .postpartum-text + .postpartum-text {
        margin-top: 20px;
    }

    .postpartum-wrap .postpartum-media {
        border-radius: 12px;
    }

    .postpartum-wrap .postpartum-point-list {
        margin-top: 36px;
        flex-direction: column;
        gap: 28px;
    }

    .postpartum-wrap .postpartum-point-item {
        width: 100%;
    }

    .postpartum-wrap .postpartum-point-title {
        margin: 12px 0 8px;
        font-size: 1.4rem;
    }

    .postpartum-wrap .postpartum-point-desc {
        font-size: 15px;
    }
}

@media (max-width: 768px) {
    .sub-title-wrap .sub-title {
        font-size: 1.9rem;
    }

    .sub-title-wrap .sub-title-en,
    .postpartum-wrap .postpartum-text {
        font-size: 1rem;
    }
}

@media (max-width: 500px) {
    .sub-title-wrap .sub-title {
        font-size: 1.6rem;
    }

    .sub-title-wrap .sub-title-en,
    .postpartum-wrap .postpartum-text {
        font-size: 0.95rem;
    }

    .postpartum-wrap .postpartum-point-title {
        font-size: 1.2rem;
    }
}

/* 신생아 CARE 시스템 */
.program-wrap {
    margin: 0 auto;
    padding: 50px 0;
}

.program-wrap .sub-title-wrap {
    margin-bottom: 24px;
}

.program-wrap .program-card-list {
    display: flex;
    gap: 28px;
    align-items: stretch;
}

.program-wrap .program-card-item {
    flex: 1 1 0;
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
}

.program-wrap .program-thumb img {
    display: block;
    width: 100%;
    height: auto;
}

.program-wrap .program-label {
    margin: 0;
    background: #3e2b6b;
    color: #fff;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    line-height: 1.5;
    font-weight: 600;
    padding: 14px 10px;
    min-height: 74px;
}

.program-wrap .program-maternal {
    margin: 200px 0;
}

.program-wrap .program-maternal .sub-title-wrap {
    margin-bottom: 18px;
}

.program-wrap .program-section-chip {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin: 20px 0;
    width: 260px;
    padding: 9px 16px;
    border-radius: 999px;
    background: #3e2b6b;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 600;
    line-height: 1;
}

.program-wrap .program-section-chip i {
    font-size: 0.85rem;
}

.program-wrap .program-mini-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px 24px;
    margin-bottom: 50px;
}

.program-wrap .program-mini-item {
    min-height: 120px;
    border-radius: 14px;
    background: #F0EEF3;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 34px 12px;

}

.program-wrap .program-mini-item i {
    color: #F77E0B;
    font-size: 1.02rem;
    margin-bottom: 8px;
}

.program-wrap .program-mini-item svg,
.program-wrap .program-mini-item .svg-inline--fa {
    color: #F77E0B;
    width: 2rem;
    height: 2rem;
    margin-bottom: 8px;
    display: block;
    flex: 0 0 auto;
}

.program-wrap .program-mini-item p {
    margin: 0;
    color: #2f3440;
    font-size: 1rem;
    line-height: 1.45;
    letter-spacing: -0.01em;
}

.program-wrap .program-mini-list .program-mini-item:nth-child(even) {
    background: #fff;
}

.program-wrap .program-mini-list.paid .program-mini-item {
    background: #f0eef3;
}

.program-wrap .program-mini-list.paid .program-mini-item:nth-child(2) {
    background: #fff;
}

.program-wrap .program-schedule {
    margin-top: 100px;
}

.program-wrap .program-schedule-table-wrap {
    margin-top: 18px;
    overflow-x: auto;
}

.program-wrap .program-schedule-table {
    width: 100%;
    border-collapse: collapse;
    border-top: 1px solid #8d7fb3;
    font-size: 0.88rem;
    color: #2f3440;
}

.program-wrap .program-schedule-table th,
.program-wrap .program-schedule-table td {
    padding: 8px 10px;
    border: 1px solid #e2e2e8;
    text-align: center;
    line-height: 1.35;
}

.program-wrap .program-schedule-table thead th,
.program-wrap .program-schedule-table thead td{
    border-top: 1px solid #3E2B6B;
    border-bottom: 1px solid #3E2B6B;
}

.program-wrap .program-schedule-table thead th {
    background: #F0EEF3;
    font-weight: 700;
}

.program-wrap .program-schedule-table tbody tr:nth-child(even) td,
.program-wrap .program-schedule-table tbody tr:nth-child(even) th {
    background: #F0EEF3;
}

.program-wrap .program-schedule-table tbody th {
    font-weight: 600;
    background: #fff;
    white-space: nowrap;
}

@media (max-width: 1300px) {
    .program-wrap .program-card-list {
        gap: 20px;
    }

    .program-wrap .program-label {
        font-size: 0.9rem;
        min-height: 66px;
    }

    .program-wrap .program-mini-list {
        gap: 12px 16px;
    }

    .program-wrap .program-mini-item p {
        font-size: 0.86rem;
    }
}

@media (max-width: 768px) {
    .program-wrap .program-card-list {
        flex-direction: column;
        gap: 16px;
    }

    .program-wrap .program-card-item {
        border-radius: 12px;
    }

    .program-wrap .program-maternal {
        margin: 48px 0;
    }

    .program-wrap .program-section-chip {
        font-size: 0.85rem;
        width: 230px;
        padding: 7px 14px;
    }

    .program-wrap .program-mini-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
    }

    .program-wrap .program-mini-item {
        min-height: 84px;
        border-radius: 12px;
    }

    .program-wrap .program-mini-item p {
        font-size: 0.82rem;
    }

    .program-wrap .program-schedule {
        margin-top: 56px;
    }

    .program-wrap .program-schedule-table {
        min-width: 980px;
        font-size: 0.8rem;
    }
}

@media (max-width: 500px) {
    .program-wrap .program-label {
        font-size: 0.85rem;
        padding: 12px 8px;
    }

    .program-wrap .program-mini-list {
        grid-template-columns: 1fr;
    }

    .program-wrap .program-mini-item {
        min-height: 76px;
    }
}

/* 이용안내 및 가격 */
.guide-wrap .sub-title-wrap {margin-bottom: 46px;}
.guide-wrap .guide-subhead {margin: 80px 0 14px; font-size: 1.5rem; font-weight: 700; color: #3e2b6b;}
.guide-wrap .guide-info-grid {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px 18px; margin-bottom: 54px;}
.guide-wrap .guide-info-item {background: #fff; border: 1px solid #e9e9ef; border-radius: 14px; min-height: 92px; display: flex; align-items: center; justify-content: center; text-align: center; padding: 22px 14px;}
.guide-wrap .guide-info-item p {margin: 0; font-size: 1rem; line-height: 1.45; color: #2f3440;}
.guide-wrap .guide-info-item small {font-size: 0.72rem; color: #444a57;}
.guide-wrap .guide-table-wrap {margin-top: 8px; overflow-x: auto;}
.guide-wrap .guide-table {width: 100%; min-width: 780px; border-collapse: collapse; border-top: 1px solid #3e2b6b; font-size: 0.9rem; color: #2f3440;}
.guide-wrap .guide-table th,.guide-wrap .guide-table td {padding: 8px 10px; border: 1px solid #e2e2e8; text-align: center; line-height: 1.35;}
.guide-wrap .guide-table thead th {background: #F0EEF3; font-weight: 700;}
.guide-wrap .guide-table tbody td {background: #fff;}
.guide-wrap .guide-table tbody td.no-bg {background: transparent;}
.guide-wrap .guide-notice-list {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 48px;}
.guide-wrap .guide-notice-item {background: #fff; border: 1px solid #e9e9ef; border-radius: 16px; text-align: center; padding: 34px 18px 24px;}
.guide-wrap .guide-notice-item i {display: block; margin: 0 auto 16px; font-size: 3rem; color: #F77E0B;}
.guide-wrap .guide-notice-item svg,
.guide-wrap .guide-notice-item .svg-inline--fa {display: block; width: 3rem; height: 3rem; margin: 0 auto 16px; color: #F77E0B; flex: 0 0 auto;}
.guide-wrap .guide-notice-title {margin: 0 0 10px; font-size: 2rem; font-weight: 700; line-height: 1.2; color: #F77E0B;}
.guide-wrap .guide-notice-text,.guide-wrap .guide-notice-phone {margin: 0; font-size: 1.05rem; line-height: 1.5; color: #2f3440;}
.guide-wrap .guide-notice-phone {font-size: 1.5rem; font-weight: 700;}

@media (max-width: 1300px) {
    .guide-wrap .guide-info-item p {font-size: 0.9rem;}
    .guide-wrap .guide-notice-item i {font-size: 2.4rem;}
    .guide-wrap .guide-notice-title {font-size: 1.6rem;}
    .guide-wrap .guide-notice-text,.guide-wrap .guide-notice-phone {font-size: 0.95rem;}
    .guide-wrap .guide-notice-phone {font-size: 1.5rem;}
}

@media (max-width: 768px) {
    .guide-wrap {padding: 40px 0;}
    .guide-wrap .sub-title-wrap {margin-bottom: 30px;}
    .guide-wrap .guide-subhead {font-size: 1.25rem;}
    .guide-wrap .guide-info-grid {grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 34px;}
    .guide-wrap .guide-notice-list {grid-template-columns: 1fr; gap: 12px; margin-top: 32px;}
    .guide-wrap .guide-notice-item {padding: 24px 14px 18px;}
    .guide-wrap .guide-notice-item i {font-size: 2rem; margin-bottom: 12px;}
    .guide-wrap .guide-notice-title {font-size: 1.35rem;}
    .guide-wrap .guide-notice-text,.guide-wrap .guide-notice-phone {font-size: 0.92rem;}
    .guide-wrap .guide-notice-phone {font-size: 1.3rem;}
}

@media (max-width: 500px) {
    .guide-wrap .guide-info-grid {grid-template-columns: 1fr;}
    .guide-wrap .guide-info-item {min-height: 84px;}
}

/* 공공산후조리원 */
.public-wrap {padding: 50px 0;}
.public-wrap .sub-title-wrap {margin-bottom: 32px;}
.public-wrap .public-intro {margin: 0 0 58px; font-size: 1.1rem; line-height: 1.8; color: #2f3440; font-weight: 600;}
.public-wrap .public-section {display: flex; gap: 36px; align-items: flex-start; margin-top: 56px;}
.public-wrap .public-copy,.public-wrap .public-media {flex: 1 1 0;}
.public-wrap .public-subhead {margin: 0 0 16px; font-size: 1.5rem; color: #3e2b6b; font-weight: 700;}
.public-wrap .public-basic-list {margin: 0; padding: 0; list-style: none;}
.public-wrap .public-basic-list li {margin: 0 0 8px; font-size: 1rem; color: #2f3440; line-height: 1.6;}
.public-wrap .public-basic-list li span {font-weight: 700;}
.public-wrap .public-basic-list li strong {font-weight: 700; color: #232b36;}
.public-wrap .public-basic-list li i {color: #d9382c; margin-right: 4px;}
.public-wrap .public-basic-list li.note {margin-top: -3px; font-size: 0.86rem; color: #5d6370;}
.public-wrap .public-rank-list {margin: 18px 0 0; padding: 0; list-style: none;}
.public-wrap .public-rank-list li {display: flex; gap: 10px; align-items: center; margin-bottom: 8px; font-size: 0.95rem; color: #2f3440;}
.public-wrap .public-rank-list .rank {display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 25px; padding: 0 10px; border-radius: 999px; background: #F77E0B; color: #fff; font-size: 0.82rem; font-weight: 700; line-height: 1;}
.public-wrap .public-rank-list p {margin: 0; line-height: 1.4;}
.public-wrap .public-media {border-radius: 16px; overflow: hidden; background: #ddd;}
.public-wrap .public-media img {display: block; width: 100%; height: auto;}
.public-wrap .public-support-list {margin: 0; color: #2f3440;}
.public-wrap .public-support-list dt {margin: 0 0 8px; font-size: 1.8rem; color: #3e2b6b; font-weight: 700;}
.public-wrap .public-support-list dd {margin: 0 0 6px; font-size: 1rem; line-height: 1.6;}
.public-wrap .public-support-list dt + dd {margin-top: 0;}
.public-wrap .public-support-list dd + dt {margin-top: 24px;}
.public-wrap .public-support-list dd.note {font-size: 0.86rem; color: #5d6370;}

@media (max-width: 1300px) {
    .public-wrap .public-intro {font-size: 1.05rem;}
    .public-wrap .public-subhead {font-size: 1.35rem;}
    .public-wrap .public-basic-list li,.public-wrap .public-support-list dd {font-size: 0.95rem;}
    .public-wrap .public-support-list dt {font-size: 1.5rem;}
}

@media (max-width: 768px) {
    .public-wrap {padding: 40px 0;}
    .public-wrap .sub-title-wrap {margin-bottom: 24px;}
    .public-wrap .public-intro {margin-bottom: 38px; font-size: 1rem;}
    .public-wrap .public-section {flex-direction: column; gap: 22px; margin-top: 34px;}
    .public-wrap .public-copy,.public-wrap .public-media {flex:1 1 100%; width: 100%;}
    .public-wrap .public-subhead {font-size: 1.2rem;}
    .public-wrap .public-basic-list li {font-size: 0.9rem;}
    .public-wrap .public-rank-list li {font-size: 0.88rem;}
    .public-wrap .public-support-list dt {font-size: 1.25rem;}
    .public-wrap .public-support-list dd {font-size: 0.9rem;}
}

@media (max-width: 500px) {
    .public-wrap .public-intro br {display: none;}
    .public-wrap .public-basic-list li {font-size: 0.86rem;}
    .public-wrap .public-rank-list .rank {min-width: 40px; height: 23px; font-size: 0.75rem;}
}

/* 소아청소년과 이용안내 */
.ped-wrap {padding: 50px 0;}
.ped-wrap .sub-title-wrap {margin-bottom: 48px;}
.ped-wrap .ped-subhead {display: inline-flex; align-items: center; justify-content: space-between; gap: 10px; margin: 0 0 12px; width: 190px; padding: 5px 14px!important; border-radius: 16px; background: #3e2b6b; color: #fff; font-size: 1.2rem; font-weight: 700; line-height: 1;}
.ped-wrap .ped-subhead i,.ped-wrap .ped-subhead svg {font-size: 0.9rem; color: #fff;}
.ped-wrap .ped-grid {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-bottom: 100px;}
.ped-wrap .ped-card {background: #fff; border: 1px solid #fff; border-radius: 16px; min-height: 180px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 48px 16px; color: #2f3440; text-decoration: none;}
.ped-wrap .ped-card i,.ped-wrap .ped-card svg {font-size: 2.3rem; color: #F77E0B; margin-bottom: 14px;}
.ped-wrap .ped-title {margin: 0 0 6px; font-size: 2rem; line-height: 1.2; font-weight: 700; color: #F77E0B;}
.ped-wrap .ped-desc,.ped-wrap .ped-phone {margin: 0; font-size: 1.15rem; line-height: 1.45; color: #2f3440;}
.ped-wrap .ped-note {margin: 2px 0 0; font-size: 0.9rem; color: #F77E0B;}
.ped-wrap .ped-card-link {background: #3e2b6b; border-color: #3e2b6b;}
.ped-wrap .ped-card-link i,.ped-wrap .ped-card-link svg,.ped-wrap .ped-card-link .svg-inline--fa,.ped-wrap .ped-card-link .ped-title,.ped-wrap .ped-card-link .ped-phone {color: #fff;}

@media (max-width: 1300px) {
    .ped-wrap .ped-card {min-height: 164px;}
    .ped-wrap .ped-card i,.ped-wrap .ped-card svg {font-size: 2rem;}
    .ped-wrap .ped-title {font-size: 1.65rem;}
    .ped-wrap .ped-desc,.ped-wrap .ped-phone {font-size: 0.95rem;}
}

@media (max-width: 768px) {
    .ped-wrap {padding: 40px 0;}
    .ped-wrap .sub-title-wrap {margin-bottom: 30px;}
    .ped-wrap .ped-subhead {width: 170px; font-size: 1rem; padding: 8px 12px;}
    .ped-wrap .ped-grid {grid-template-columns: 1fr; gap: 12px; margin-bottom: 34px;}
    .ped-wrap .ped-card {min-height: 146px; border-radius: 14px; padding: 20px 12px;}
    .ped-wrap .ped-card i,.ped-wrap .ped-card svg {font-size: 1.7rem; margin-bottom: 10px;}
    .ped-wrap .ped-title {font-size: 1.35rem;}
    .ped-wrap .ped-desc,.ped-wrap .ped-phone {font-size: 0.9rem;}
}

/* 예방접종 */
.vaccin-wrap {padding: 50px 0;}
.vaccin-wrap .sub-title-wrap {margin-bottom: 42px;}
.vaccin-wrap .vaccin-intro-section {background: #fff; border-top: 1px solid #ededf1; border-bottom: 1px solid #ededf1; padding: 46px 0 36px;}
.vaccin-wrap .vaccin-intro-box {text-align: center; max-width: 1100px; margin: 0 auto;}
.vaccin-wrap .vaccin-intro-title {margin: 0 0 16px; font-size: 2rem; color: #3e2b6b; font-weight: 700; line-height: 1.25;}
.vaccin-wrap .vaccin-intro-text {margin: 0; font-size: 1.03rem; line-height: 1.9; color: #2f3440; word-break: keep-all;}
.vaccin-wrap .vaccin-intro-text + .vaccin-intro-text {margin-top: 10px;}
.vaccin-wrap .vaccin-point-list {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; margin-top: 30px; padding-top: 22px; border-top: 1px solid #d9d3e4;}
.vaccin-wrap .vaccin-point-item {text-align: center;}
.vaccin-wrap .vaccin-point-icon {width: 88px; height: 88px; margin: 0 auto 10px; border-radius: 50%; background: #f6ecdf; display: inline-flex; align-items: center; justify-content: center;}
.vaccin-wrap .vaccin-point-icon i,.vaccin-wrap .vaccin-point-icon svg {font-size: 2.05rem; color: #f77e0b;}
.vaccin-wrap .vaccin-point-text {margin: 0; font-size: 1.25rem; line-height: 1.3; color: #232b36; font-weight: 600;}
.vaccin-wrap .vaccin-title-box {margin-top: 52px; margin-bottom: 24px;}
.vaccin-wrap .vaccin-note-group + .vaccin-note-group {margin-top: 30px;}
.vaccin-wrap .vaccin-note-title {margin: 0 0 12px; font-size: 1.35rem; line-height: 1.35; color: #3e2b6b; font-weight: 700;}
.vaccin-wrap .vaccin-note-list {margin: 0; padding: 0; list-style: none;}
.vaccin-wrap .vaccin-note-list li {position: relative; margin: 0 0 8px; padding-left: 14px; font-size: 1rem; line-height: 1.65; color: #2f3440; word-break: keep-all;}
.vaccin-wrap .vaccin-note-list li::before {content: "-"; position: absolute; left: 0; top: 0; color: #666d7a;}
.vaccin-wrap .vaccin-note-paragraph {margin: 0; font-size: 1rem; line-height: 1.8; color: #2f3440; word-break: keep-all;}
.vaccin-wrap .vaccin-table-wrap {margin-top: 8px;}
.vaccin-wrap .vaccin-table thead th {font-size: 0.95rem; padding: 9px 8px;}
.vaccin-wrap .vaccin-table tbody td,.vaccin-wrap .vaccin-table tbody th {padding: 9px 8px; font-size: 0.88rem; line-height: 1.4;}
.vaccin-wrap .vaccin-table tbody th {font-weight: 600; white-space: nowrap;}
.vaccin-wrap .vaccin-standard-list {margin: 0; padding: 0; list-style: none;}
.vaccin-wrap .vaccin-standard-list > li {margin: 0 0 20px;}
.vaccin-wrap .vaccin-standard-title {margin: 0 0 6px; font-size: 1.35rem; line-height: 1.35; color: #3e2b6b; font-weight: 700;}
.vaccin-wrap .vaccin-standard-text {margin: 0; font-size: 1rem; line-height: 1.7; color: #2f3440; word-break: keep-all;}
.vaccin-wrap .vaccin-standard-sub {margin: 2px 0 0; font-size: 0.86rem; line-height: 1.6; color: #666d7a; word-break: keep-all;}

@media (max-width: 1300px) {
    .vaccin-wrap .vaccin-intro-title {font-size: 1.8rem;}
    .vaccin-wrap .vaccin-intro-text {font-size: 0.96rem; line-height: 1.8;}
    .vaccin-wrap .vaccin-point-icon {width: 78px; height: 78px;}
    .vaccin-wrap .vaccin-point-icon i,.vaccin-wrap .vaccin-point-icon svg {font-size: 1.8rem;}
    .vaccin-wrap .vaccin-point-text {font-size: 1.08rem;}
    .vaccin-wrap .vaccin-note-title {font-size: 1.2rem;}
    .vaccin-wrap .vaccin-note-list li {font-size: 0.94rem;}
    .vaccin-wrap .vaccin-note-paragraph {font-size: 0.94rem;}
    .vaccin-wrap .vaccin-table thead th {font-size: 0.88rem;}
    .vaccin-wrap .vaccin-table tbody td,.vaccin-wrap .vaccin-table tbody th {font-size: 0.82rem; padding: 8px 6px;}
    .vaccin-wrap .vaccin-standard-title {font-size: 1.5rem;}
    .vaccin-wrap .vaccin-standard-text {font-size: 0.94rem;}
    .vaccin-wrap .vaccin-standard-sub {font-size: 0.8rem;}
}

@media (max-width: 768px) {
    .vaccin-wrap {padding: 40px 0;}
    .vaccin-wrap .vaccin-intro-section {padding: 34px 0 26px;}
    .vaccin-wrap .vaccin-intro-title {font-size: 1.5rem; margin-bottom: 12px;}
    .vaccin-wrap .vaccin-intro-text {font-size: 0.9rem; line-height: 1.7;}
    .vaccin-wrap .vaccin-point-list {grid-template-columns: 1fr; gap: 14px; margin-top: 22px; padding-top: 18px;}
    .vaccin-wrap .vaccin-point-item {display: flex; align-items: center; justify-content: flex-start; text-align: left; gap: 10px;}
    .vaccin-wrap .vaccin-point-icon {margin: 0; width: 56px; height: 56px;}
    .vaccin-wrap .vaccin-point-icon i,.vaccin-wrap .vaccin-point-icon svg {font-size: 1.25rem;}
    .vaccin-wrap .vaccin-point-text {font-size: 1rem;}
    .vaccin-wrap .vaccin-title-box {margin-top: 32px; margin-bottom: 16px;}
    .vaccin-wrap .vaccin-note-group + .vaccin-note-group {margin-top: 22px;}
    .vaccin-wrap .vaccin-note-title {font-size: 1.08rem;}
    .vaccin-wrap .vaccin-note-list li {font-size: 0.9rem; line-height: 1.6; margin-bottom: 6px;}
    .vaccin-wrap .vaccin-note-paragraph {font-size: 0.9rem; line-height: 1.7;}
    .vaccin-wrap .vaccin-table-wrap {overflow-x: auto;}
    .vaccin-wrap .vaccin-table {min-width: 780px;}
    .vaccin-wrap .vaccin-standard-list > li {margin-bottom: 16px;}
    .vaccin-wrap .vaccin-standard-title {font-size: 1.2rem; margin-bottom: 4px;}
    .vaccin-wrap .vaccin-standard-text {font-size: 0.9rem; line-height: 1.6;}
    .vaccin-wrap .vaccin-standard-sub {font-size: 0.78rem; line-height: 1.5;}
}

/* 피부질환 */
.skin-wrap .skin-intro {margin-top: 24px;}
.skin-wrap .skin-paragraph {margin: 0 0 18px; font-size: 1rem; line-height: 1.8; color: #2f3440; word-break: keep-all;}
.skin-wrap .skin-clinic {margin-bottom: 0;}
.skin-wrap .skin-clinic strong {font-size: 1.15rem; color: #232b36;}
.skin-wrap .skin-media {flex: 0 0 43%;}
.skin-wrap .skin-title-box {margin-top: 42px; margin-bottom: 18px;}
.skin-wrap .skin-desc-main {margin: 0 0 18px; font-size: 1.35rem; line-height: 1.55; color: #232b36; font-weight: 700; word-break: keep-all;}
.skin-wrap .skin-cause-wrap {margin-top: 6px;}
.skin-wrap .skin-cause-grid {display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 10px; margin: 14px 0 16px;}
.skin-wrap .skin-cause-item {background: #fff; border: 1px solid #e6e6ee; border-radius: 14px; min-height: 104px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 12px 8px;}
.skin-wrap .skin-cause-item i,.skin-wrap .skin-cause-item svg {font-size: 2rem; color: #f77e0b; margin-bottom: 8px;}
.skin-wrap .skin-cause-item p {margin: 0; font-size: 1.35rem; line-height: 1.3; color: #2f3440; font-weight: 600;}

@media (max-width: 1300px) {
    .skin-wrap .skin-paragraph {font-size: 0.95rem;}
    .skin-wrap .skin-clinic strong {font-size: 1.05rem;}
    .skin-wrap .skin-desc-main {font-size: 1.15rem;}
    .skin-wrap .skin-cause-grid {grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 8px;}
    .skin-wrap .skin-cause-item {min-height: 96px;}
    .skin-wrap .skin-cause-item i,.skin-wrap .skin-cause-item svg {font-size: 1.7rem;}
    .skin-wrap .skin-cause-item p {font-size: 1.08rem;}
}

@media (max-width: 768px) {
    .skin-wrap .skin-intro {margin-top: 10px;}
    .skin-wrap .skin-media {flex: none;}
    .skin-wrap .skin-title-box {margin-top: 28px; margin-bottom: 14px;}
    .skin-wrap .skin-paragraph {font-size: 0.9rem; line-height: 1.7; margin-bottom: 14px;}
    .skin-wrap .skin-clinic strong {font-size: 1rem;}
    .skin-wrap .skin-desc-main {font-size: 1.02rem; line-height: 1.5; margin-bottom: 12px;}
    .skin-wrap .skin-cause-grid {grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin: 10px 0 12px;}
    .skin-wrap .skin-cause-item {min-height: 84px; border-radius: 12px; padding: 10px 6px;}
    .skin-wrap .skin-cause-item i,.skin-wrap .skin-cause-item svg {font-size: 1.35rem; margin-bottom: 6px;}
    .skin-wrap .skin-cause-item p {font-size: 0.9rem;}
}

/* 소아신경질환 */
.nerves-wrap .nerves-intro {margin-top: 22px;}
.nerves-wrap .nerves-paragraph {margin: 0 0 20px; font-size: 1rem; line-height: 1.8; color: #2f3440; word-break: keep-all;}
.nerves-wrap .nerves-paragraph:last-child {margin-bottom: 0;}
.nerves-wrap .nerves-media {flex: 0 0 42%;}
.nerves-wrap .nerves-title-box {margin-top: 36px; margin-bottom: 12px;}
.nerves-wrap .nerves-card-grid {display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin: 8px 0 10px;}
.nerves-wrap .nerves-card-grid.types {margin-top: 10px;}
.nerves-wrap .nerves-card-item {background: #fff; border: 1px solid #e6e6ee; border-radius: 12px; min-height: 52px; padding: 9px 12px; display: flex; align-items: center; justify-content: center; text-align: center; line-height: 1.4; color: #3e2b6b; font-size: 1.25rem; font-weight: 600; word-break: keep-all;}
.nerves-wrap .nerves-note {margin: 0 0 12px; font-size: 0.78rem; line-height: 1.6; color: #666d7a;}
.nerves-wrap .nerves-highlight {font-weight: 700; color: #232b36;}
.nerves-wrap .nerves-clinic-media {margin: 6px 0 10px; border-radius: 16px; overflow: hidden; background: #ddd;}
.nerves-wrap .nerves-clinic-media img {display: block; width: 100%; height: auto;}
.nerves-wrap .nerves-clinic-copy {margin-bottom: 0;}

@media (max-width: 1300px) {
    .nerves-wrap .nerves-paragraph {font-size: 0.95rem;}
    .nerves-wrap .nerves-card-item {font-size: 1.05rem;}
}

@media (max-width: 768px) {
    .nerves-wrap .nerves-intro {margin-top: 10px;}
    .nerves-wrap .nerves-paragraph {font-size: 0.9rem; line-height: 1.7; margin-bottom: 14px;}
    .nerves-wrap .nerves-media {flex: none;}
    .nerves-wrap .nerves-title-box {margin-top: 26px; margin-bottom: 10px;}
    .nerves-wrap .nerves-card-grid {grid-template-columns: 1fr; gap: 6px;}
    .nerves-wrap .nerves-card-item {font-size: 0.9rem; min-height: 44px; padding: 8px 10px;}
    .nerves-wrap .nerves-note {font-size: 0.74rem; margin-bottom: 10px;}
    .nerves-wrap .nerves-clinic-media {border-radius: 12px; margin: 4px 0 8px;}
}

/* 영유아 건강검진 */
.health-wrap .health-checkup-section {margin-top: 2px;}
.health-wrap .health-compact {margin-bottom: 10px;}
.health-wrap .health-table-wrap {margin-top: 6px;}
.health-wrap .health-table thead th {font-size: 0.72rem; padding: 8px 6px; letter-spacing: -0.02em;}
.health-wrap .health-table tbody td,.health-wrap .health-table tbody th {padding: 8px 6px; font-size: 0.72rem; line-height: 1.35; text-align: center;}
.health-wrap .health-table tbody th {font-weight: 600; white-space: nowrap;}
.health-wrap .health-dot {display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: #f77e0b; vertical-align: middle;}
.health-wrap .health-note-wrap {margin-top: 12px;}
.health-wrap .health-note-title {margin: 0 0 6px; font-size: 0.98rem; color: #3e2b6b; font-weight: 700;}
.health-wrap .health-note-list {margin: 0; padding: 0; list-style: none;}
.health-wrap .health-note-list li {position: relative; margin: 0 0 4px; padding-left: 14px; font-size: 0.92rem; line-height: 1.5; color: #2f3440; word-break: keep-all;}
.health-wrap .health-note-list li::before {content: ""; position: absolute; left: 0; top: 0.52em; width: 8px; height: 8px; border-radius: 2px; background: #3e2b6b; transform: translateY(-50%);}
.health-wrap .health-btn-wrap {text-align: center; margin-top: 16px;}
.health-wrap .health-orange-btn {display: inline-flex; align-items: center; justify-content: center; flex-direction: column; gap: 2px; min-width: 210px; padding: 10px 20px; border-radius: 10px; background: #f77e0b; color: #fff; font-size: 1.05rem; font-weight: 700; line-height: 1.2;}
.health-wrap .health-orange-btn i,.health-wrap .health-orange-btn svg {font-size: 1rem;}
.health-wrap .health-orange-btn small {display: block; font-size: 0.72rem; font-weight: 500; opacity: 0.95;}

@media (max-width: 1300px) {
    .health-wrap .health-table thead th {font-size: 0.68rem;}
    .health-wrap .health-table tbody td,.health-wrap .health-table tbody th {font-size: 0.68rem;}
    .health-wrap .health-note-title {font-size: 0.92rem;}
    .health-wrap .health-note-list li {font-size: 0.86rem;}
}

@media (max-width: 768px) {
    .health-wrap .health-table-wrap {overflow-x: auto;}
    .health-wrap .health-table {min-width: 860px;}
    .health-wrap .health-note-title {font-size: 0.88rem;}
    .health-wrap .health-note-list li {font-size: 0.82rem; margin-bottom: 3px;}
    .health-wrap .health-orange-btn {min-width: 190px; padding: 9px 14px; font-size: 0.92rem;}
    .health-wrap .health-orange-btn small {font-size: 0.68rem;}
}

@media (max-width: 1024px) {
    .inner {
        width: 92%;
    }

    .section-pa {
        padding: 64px 0;
    }

    .section-ma {
        margin: 32px 0;
    }

    .section-flex {
        gap: 20px;
    }

    .flex-half {
        padding: 16px;
    }

    .title-purple-box {
        margin: 56px 0 20px;
    }
}

@media (max-width: 768px) {
    .inner {
        width: 94%;
    }

    .section-pa {
        padding: 48px 0;
    }

    .section-ma {
        margin: 24px 0;
    }

    .section-flex {
        flex-direction: column;
        align-items: stretch;
        gap: 16px;
    }
    .section-flex .title-small {
        font-size: 1rem;
    }

    .flex-half {
        flex: none;
        width: 100%;
        padding: 12px 0;
    }

    .title-purple-box {
        min-width: 0;
        font-size: 1rem;
        margin: 40px 0 16px;
        padding: 12px 52px 12px 14px;
        border-radius: 14px;
    }

    .title-purple-box .icon-title-after {
        right: 12px;
        font-size: 1rem;
    }

    .table-list {
        overflow-x: auto;
    }
    /*
    .table-list table {
        min-width: 680px;
    }*/

    .table-list tbody td,
    .table-list tbody th {
        padding: 14px 12px;
    }

    .tabs {
        justify-content: center;
        padding: 24px 0;
    }

    .tabs .tab {
        margin: 4px 2px 4px 0;
    }

    .tabs .tab a {
        font-size: 1rem;
        padding: 10px 14px;
        border-radius: 12px;
    }

    p {
        font-size: 1rem;
    }

    .box1 {
        border-radius: 16px;
        padding: 24px 18px;
    }

    .box1 .icon,
    .box-basic .icon {
        font-size: 1.7rem;
        padding-bottom: 24px;
    }

    .box1 h5,
    h5 {
        font-size: 1.45rem;
        padding-bottom: 12px;
    }

    .box1 p,
    .box-basic p {
        font-size: 0.95rem;
        line-height: 1.65;
    }

    .box-basic {
        padding: 16px 0;
    }
}

@media (max-width: 500px) {
    .title-purple-box {
        font-size: 0.95rem;
        padding-right: 46px;
    }
    /*
    .table-list table {
        min-width: 560px;
    }

     */
}


