@font-face{
    font-family:'SchoolSafetyWave';
    src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2402_keris@1.0/TTHakgyoansimMulgyeolB.woff2') format('woff2');
    font-weight:700;
    font-style:normal;
    font-display:swap;
}
html{
    font-size:16px;
    scroll-behavior:smooth;
}
*{box-sizing:border-box;}
body{
    margin:0;
    min-width:1200px;
    font-family:"Noto Sans KR",sans-serif;
}
ul,ol{
    margin:0;
    padding:0;
    list-style:none;
}
a{
    color:inherit;
    text-decoration:none;
}
button{font:inherit;}
.wrap{
    position:relative;
    background:#02021b;
    color:#fff;
}
.site-header{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    z-index:30;
    transition:all .25s ease;
    background:transparent;
}
.site-header .header-inner{
    width:1200px;
    height:6rem;
    margin:0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
}
.site-header.is-sticky{
    position:fixed;
    top:0;
    left:0;
    background:rgba(4,11,45,.93);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(255,255,255,.08);
    box-shadow:0 8px 24px rgba(0,0,0,.25);
}
.site-header.is-sticky .header-inner{
    height:6.3rem;
}
.gnb{
    display:flex;
    align-items:center;
    gap:2.9rem;
    font-size:1.6rem;
    font-weight:700;
    letter-spacing:-.04em;
}
.gnb>li{
    position:relative;
}
.gnb>li>a{
    display:inline-flex;
    align-items:center;
    height:6rem;
    font-size:1rem;
    transition:color .2s ease;
}
.site-header.is-sticky .gnb>li>a{
    height:4.9rem;
}
.gnb>li:hover>a{
    color:#69b8ff;
}
.submenu{
        position: absolute;
    top: calc(100% - 20px);
    left: 50%;
    transform: translateX(-50%) translateY(8px);
    min-width: 180px;
    padding: .9rem 0;
    background: rgba(5, 14, 55, .97);
    border: 1px solid rgba(255, 255, 255, .12);
    opacity: 0;
    visibility: hidden;
    transition: all .22s ease;
}
.gnb>li:hover .submenu{
    opacity:1;
    visibility:visible;
    transform:translateX(-50%) translateY(0);
}
.submenu a{
    display:block;
    padding:.6rem 1.3rem;
    font-size:.9rem;
    font-weight:500;
    color:rgba(255,255,255,.86);
    white-space:nowrap;
}
.submenu a:hover{
    color:#7ec8ff;
    background:rgba(255,255,255,.04);
}
.top-visual{
    position:relative;
    min-height:45.3rem;
    overflow:hidden;
}
.top-visual::after{
    content:"";
    position:absolute;
    inset:0;
    background:url("../images/bg_visual.png") no-repeat calc(50% + 225px) center;
    background-size:auto 100%;
    animation:visualFocus 1.6s ease forwards;
}
@keyframes visualFocus{
    from{filter:blur(10px); opacity:.4;}
    to{filter:blur(0); opacity:1;}
}
.top-inner{
    position:relative;
    z-index:1;
    width:1140px;
    min-height:45.3rem;
    margin:0 auto;
    display:flex;
    align-items:center;
}
.copy{
    padding-left:1.8rem;
    margin-top:1.6rem;
}
.copy .eyebrow{
    position:relative;
    padding-left:0;
    font-size:1.4rem;
    font-weight:700;
    line-height:1.5;
}
.copy .eyebrow::before{
    content:"";
    position:absolute;
    left:-28px;
    top:6px;
    width:6px;
    height:calc(100% + 170px);
    background:#fff;
}
.title{
    margin:0 0 2.1rem 0;
    margin-left:-10px;
    font-size:3.4rem;
    line-height:1.14;
    font-weight:800;
    word-break:keep-all;
}
.title b{
    display:inline-block;
    font-size:4.4rem;
    font-family:'SchoolSafetyWave';
    transform:scaleX(.85);
}
.meta{
    margin-top:0;
    font-size:1.1rem;
    line-height:1.62;
    color:rgba(255,255,255,.9);
    letter-spacing:-.03em;
}
.top_btn{
    display:flex;
    gap:1.3rem;
    margin-top:2.8rem;
    color:#fff;
}
.btn{
    min-width:14.4rem;
    height:4.1rem;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:1.3rem;
    border:1px solid rgba(255,255,255,.45);
    font-size:1rem;
    font-weight:500;
    transition:all .2s ease;
}
.btn::after{
    content:"";
    display:inline-block;
    width:24px;
    height:24px;
    flex-shrink:0;
    background-repeat:no-repeat;
    background-position:center;
    background-size:24px 24px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M13.5 4.5 21 12m0 0-7.5 7.5M21 12H3'/%3E%3C/svg%3E");
}
.btn-primary{
    background:#2953c7;
    border-color:#2953c7;
}
.btn-primary:hover{
    background:#3561dc;
    border-color:#3561dc;
}
.btn-outline{
    background:transparent;
}
.btn-outline::after{
    content:"";
    display:inline-block;
    width:24px;
    height:24px;
    flex-shrink:0;
    background-repeat:no-repeat;
    background-position:center;
    background-size:24px 24px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23ffffff' stroke-width='1.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M3 16.5v2.25A2.25 2.25 0 0 0 5.25 21h13.5A2.25 2.25 0 0 0 21 18.75V16.5M16.5 12 12 16.5m0 0L7.5 12m4.5 4.5V3'/%3E%3C/svg%3E");
}
.btn-outline:hover{
    background:rgba(255,255,255,.08);
}
.overview-section{
    position:relative;
    background:linear-gradient(90deg,#326e88 0%,#1c1b74 100%);
    padding:5rem 0;
}
.overview-section::before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(180deg,rgba(255,255,255,.04) 0%,rgba(255,255,255,0) 22%);
    pointer-events:none;
}
.event-info-wrap{
    width:100%;
    background:#f9f9f9;
    padding:5rem 0;
}
.event-info-wrap .inner{
    max-width:1140px;
    margin:0 auto;
}
.event-info-list li{
    display:flex;
    align-items:center;
    min-height:3.4rem;
    border-bottom:1px solid #e4e4e4;
}
.event-info-list .label{
    position:relative;
    flex:0 0 10.9rem;
    padding:0 3rem 0 1.4rem;
    font-size:1rem;
    font-weight:700;
    color:#222;
    text-align:center;
}
.event-info-list .label::after{
    content:"";
    position:absolute;
    top:50%;
    right:22px;
    width:1px;
    height:14px;
    background:#e4e4e4;
    transform:translateY(-50%);
}
.event-info-list .value{
    flex:1;
    padding:0 1.4rem 0 .5rem;
    font-size:1rem;
    font-weight:400;
    line-height:1.7;
    color:#222;
    word-break:keep-all;
}
.program-wrap{
    max-width:1140px;
    margin:5rem auto;
}
.program-title{
    margin:0 0 2.1rem;
    text-align:center;
    font-size:1.4rem;
    font-weight:700;
    letter-spacing:-.03em;
    color:#222;
}
.program-table{
    width:100%;
    font-size:.9rem;
    border-top:1px solid #4a4a4a;
}
.program-row{
    display:flex;
    align-items:center;
    min-height:3.1rem;
    border-bottom:1px solid #d9d9d9;
    font-weight:500;
}
.program-time{
    width:24%;
    padding:0 .6rem 0 0;
    text-align:center;
}
.program-type{
    padding:0 .6rem 0 0;
}
.program-desc.multi-line{
    padding:.4rem 0;
    line-height:1.7;
}
.badge-black{
    padding:.3rem 1rem;
    border-radius:1rem;
    background:#222;
    color:#fff;
    font-size:.9rem;
}
.section-row{
    background:#dbe1f1;
}
.section-row .program-time{
    visibility:hidden;
}
.section-label{
    width:21%;
    flex-shrink:0;
    padding:0 .6rem 0 0;
}
.badge-blue{
    padding:.3rem 1rem;
    border-radius:1rem;
    background:#2d58c6;
    color:#fff;
    font-size:.9rem;
    line-height: 1.5;
}
.section-title{
    flex:1;
    font-size:1rem;
    font-weight:700;
    letter-spacing:-.03em;
    color:#2d58c6;
}
.program-note{
    margin:1.1rem 0 0;
    text-align:right;
    font-size:.9rem;
    font-weight:400;
    letter-spacing:-.03em;
    color:#555;
}
.program-btn-wrap{
    margin-top:3.3rem;
    text-align:center;
    color:#fff;
}
.section-copy{
    width:1140px;
    margin:0 auto;
    font-size:1.1rem;
    line-height:1.4;
    color:rgba(255,255,255,.96);
    word-break:keep-all;
}
.section-copy p{
    margin:0 0 .6rem;
}
.section-copy p b{
    color:#0febff;
    font-weight:600;
}
.site-footer{
    background:#02021b;
    padding:1.6rem 1.3rem 1.9rem;
}
.footer-inner{
    text-align:center;
    font-size:.9rem;
    color:#fff;
}


#overview,#intro,#program{
    scroll-margin-top: 7rem;
}
/* =========================
   Responsive
========================= */
@media (max-width:1024px){
    body{
        min-width:100%;
    }

    .site-header .header-inner, .top-inner, .section-copy, .event-info-wrap .inner, .program-wrap{
        width:calc(100% - 40px);
        max-width:1140px;
    }

    .site-header .header-inner{
        height:5.3rem;
    }

    .site-header.is-sticky .header-inner{
        height:5.3rem;
    }

    .gnb{
        gap:1.8rem;
    }

    .gnb > li > a,
    .site-header.is-sticky .gnb > li > a{
        height:5.3rem;
        font-size:.9rem;
    }

    .top-visual{
        min-height:auto;
        padding:8rem 0 4rem;
        background-position:center center;
        background-size:cover;
        overflow:hidden;
        
    }

    .top-visual::after{
       background:
            linear-gradient(rgba(0,0,0,.28), rgba(0,0,0,.9)),
            url("../images/bg_visual.png") no-repeat center center;
        background-size:cover;
    }

    .top-inner{
        position:relative;
        z-index:1;
        width:calc(100% - 40px);
        min-height:auto;
        display:block;
    }

    .copy{
        width:100%;
        padding-left:1.1rem;
        margin-top:0;
    }

    .copy .eyebrow{
        font-size:1.3rem;
    }

    .copy .eyebrow::before{
        display: none;
    }

    .title{
        margin:0 0 1.6rem 0;
        font-size:2.8rem;
        line-height:1.2;
    }

    .title b{
        font-size:3.5rem;
        margin-left: -.3rem;
    }

    .meta{
        font-size:1rem;
        line-height:1.6;
    }

    .top_btn{
        gap:.9rem;
        margin-top:2rem;
    }

    .btn{
        min-width:11.9rem;
        height:3.6rem;
        gap:.9rem;
        font-size:.9rem;
    }

    .overview-section,
    .event-info-wrap{
        padding:4rem 0;
    }

    .event-info-list li{
        display:block;
        padding:.9rem 0;
        min-height:auto;
    }

    .event-info-list .label{
        display:block;
        flex:none;
        padding:0;
        margin-bottom:.4rem;
        text-align:left;
    }

    .event-info-list .label::after{
        display:none;
    }

    .event-info-list .value{
        display:block;
        padding:0;
        font-size:.95rem;
        line-height:1.6;
    }

    .program-wrap{
        margin:4rem auto;
    }

    .program-title{
        margin:0 0 1.6rem;
        font-size:1.2rem;
    }

    .program-row{
        display:block;
        padding:.9rem 0;
        min-height:auto;
        text-align-last: center;
    }

    .program-time,
    .program-type,
    .program-desc,
    .section-label,
    .section-title{
        width:100%;
        padding:0;
        text-align:left;
    }

    .program-time{
        margin-bottom:.5rem;
        font-size:.9rem;
        color:#666;
    }

    .program-type{
        margin-bottom:.5rem;
    }

    .program-desc{
        font-size:.9rem;
        line-height:1.6;
    }

    .program-desc.multi-line{
        padding:0;
    }

    .section-row{
        padding:.9rem 0;
        
    }

    .section-row .program-time{
        display:none;
    }

    .section-label{
        margin-bottom:.5rem;
    }

    .section-title{
        font-size:.95rem;
        line-height:1.5;
    }

    .program-note{
        font-size:.8rem;
    }

    .program-btn-wrap{
        margin-top:2rem;
    }
}

@media (max-width:767px){
    .site-header{
        position:fixed;
        background:rgba(4,11,45,.93);
        backdrop-filter:blur(10px);
        border-bottom:1px solid rgba(255,255,255,.08);
    }

    .site-header .header-inner,
    .site-header.is-sticky .header-inner,
    .top-inner,
    .section-copy,
    .event-info-wrap .inner,
    .program-wrap{
        width:calc(100% - 32px);
    }

    .site-header .header-inner,
    .site-header.is-sticky .header-inner{
        height:4rem;
    }

    .site-header .header-inner > a img{
        max-height:28px;
        width:auto;
        display:block;
    }

    .gnb{
        gap:1rem;
        justify-content:flex-end;
        flex-wrap:wrap;
        overflow:visible;
    }

    .gnb::-webkit-scrollbar{
        display:none;
    }

    .gnb > li > a,
    .site-header.is-sticky .gnb > li > a{
        height:4rem;
        font-size:.8rem;
        white-space:nowrap;
    }

     .gnb > li.has-submenu{
        position:relative;
    }

    .gnb > li.has-submenu > a{
        position:relative;
        padding-right:1rem;
    }

    .gnb > li.has-submenu > a::after{
        content:"";
        position:absolute;
        top:51%;
        right:0;
        width:8px;
        height:8px;
        border-right:1.5px solid #fff;
        border-bottom:1.5px solid #fff;
        transform:translateY(-65%) rotate(45deg);
        transition:transform .2s ease;
    }

    .gnb > li.has-submenu .submenu{
        display: none;
        position: absolute;
        top: calc(100% - 0.5rem);
        padding: .5rem 0;
        background: rgba(5, 14, 55, .97);
        border: 1px solid rgba(255, 255, 255, .12);
        border-radius: .7rem;
        opacity: 1;
        visibility: visible;
        z-index: 10;
    }

    .gnb > li.has-submenu.open .submenu{
        display:block;
    }

    .gnb > li.has-submenu.open > a::after{
        transform:translateY(-35%) rotate(-135deg);
        top: 53%;
    }

    .gnb > li.has-submenu .submenu a{
        display:block;
        padding:.6rem .9rem;
        font-size:.8rem;
        white-space:nowrap;
    }


    .copy{
        padding-left:1rem;
    }

    .title{
        margin:0 0 1.1rem 0;
        font-size:1.9rem;
    }

    .title b{
        font-size:2.5rem;
    }

    .meta{
        font-size:.9rem;
        line-height:1.6;
    }

    .top_btn{
        flex-direction:column;
        gap:.6rem;
        margin-top:1.5rem;
    }

    .btn{
        width:100%;
        min-width:100%;
        height:3.3rem;
        gap:.6rem;
        font-size:.9rem;
    }

    .btn::after,
    .btn-outline::after{
        width:20px;
        height:20px;
        background-size:20px 20px;
    }

    .overview-section,
    .event-info-wrap{
        padding:2.8rem 0;
    }

    .section-copy{
        font-size:.9rem;
        line-height:1.7;
    }

    .section-copy p{
        margin:0 0 .5rem;
    }

    .program-wrap{
        margin:2.8rem auto;
    }

    .program-title{
        margin:0 0 1.2rem;
        font-size:1.1rem;
    }

    .program-time{
        font-size:.8rem;
    }

    .program-desc{
        font-size:.9rem;
    }

    .badge-black,
    .badge-blue{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        min-height:1.9rem;
        padding:.3rem .8rem;
        font-size:.8rem;
    }

    .section-title{
        font-size:.9rem;
    }

    .program-note{
        font-size:.8rem;
    }

    .site-footer{
        padding:1.3rem 1rem 1.5rem;
    }

    .footer-inner{
        font-size:.8rem;
        line-height:1.5;
    }
}