/* BASIC css start */
/* ¹è³Ê */
.bnr img{width:100%}
#header { display:none !important; }
body #header3{ display:block !important; position: fixed; top: 0; z-index: 99; }
body #header3 img {}

#header3 .headerBottom h1 {
    padding: 0;
    line-height: 1;
    font-size: inherit;
}

.content-block{margin:0 24px}

.book-info-box{    border: 1px solid #DDDDDD;
    padding: 32px 16px;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin: 0 24px;
    flex-direction: column;}
    
.book-list{text-align: left; margin-top: 32px;}
    
.book-list .list-title{    position: relative;
    font-size: 22px;
    font-weight: 800;
    color: #000;}


.book-list .list-title .ic{width:20px}
    
.book-list .list-title em{color:#999}

.book-language{    margin: 24px 0;}

.book-language img{width: 100%;}

.view-more-link{    gap: 10px;
    display: flex;
    height: 52px;
    width: 100%;
    background: #000;
    color: #fff;
    text-align: center;
    line-height: 52px;
    font-size: 14px;
    font-weight: 700;
    margin-top: 36px;
    align-items: center;
    justify-content: center;}
    

.view-more-link img{width:auto !important}



   
.pointG{color:#A6A6A6}

.intro-section {
    padding: 0; 
}

.intro-content-wrapper {}

.intro-image-container {
    flex: 1;
    background: url(/design/taetea/mimg/page7/02.png) no-repeat;
    background-size: cover;
    background-position: top left;}
.img-right{flex:2;
    display: flex;
    gap: 32px;
    flex-direction: column;
    }

.intro-text-container {
    flex: 1;
    
    padding: 28px 24px 80px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.section-title {    font-size: 35px;
    font-weight: 700;
    line-height: 52px;
}

.subtitle-2 {    font-size: 16px;
    font-weight: 700;
    margin-bottom: 40px;
    line-height: 35px;
}

.description {
    font-size: 15px;
    line-height: 26px;
    color: #000000;
}


/* ÀüÃ¼ ¼½¼Ç ½ºÅ¸ÀÏ */
.tea-leisure-section-full {
}


.leisure-content-wrapper {
    display: flex;
    min-height: 800px; /* ÀüÃ¼ ¼½¼Ç ³ôÀÌ ÁöÁ¤ (ÀÌ¹ÌÁö Å©±â¿¡ ¸ÂÃã) */
}


.tea-leisure-section-full .leisure-content-wrapper{margin-bottom: 80px;}

.leisure-text-block.block-1{
    display: flex;
    gap: 20px;
    margin-right: 20px;}

.leisure-text-block:before{
    display:none; 
    content: "-";
    height: 3px;
    width: 24px;
    background: #000;
    margin-bottom: 28px;
    font-size:0;}

/* ¿ÞÂÊ: ÀÌ¹ÌÁö ÄÁÅ×ÀÌ³Ê */
.leisure-image-container-split {
    flex: 1; /* ¿ÞÂÊ Àý¹Ý */
    /* ÀÌ¹ÌÁö¿Í ÅØ½ºÆ® »çÀÌÀÇ ¿©¹éÀ» ¸ÂÃß±â À§ÇØ ³Êºñ Á¶Á¤ °¡´É */
}

.split-tea-cup {
    height: 100%;
    /* ÀÌ¹ÌÁö ºñÀ²À» ¸ÂÃß±â À§ÇÑ ½ºÅ¸ÀÏ */
    background-color: #f0f0f0;
    background-image: url('image_737c29.png'); /* ½ÇÁ¦ ÀÌ¹ÌÁö ÆÄÀÏ¸í */
    background-size: cover;
    background-position: center;
}

.leisure-text-content-split {
    flex: 1;
}

/* ¸ÞÀÎ Á¦¸ñ/ºÎÁ¦¸ñ ½ºÅ¸ÀÏ */
.leisure-title-main {
    padding: 0 24px;
    color: #000;
    font-size: 18px;
    font-weight: 700;
    line-height: 44px;
}

.leisure-subtitle-main {
    font-size: 36px;
    font-weight: 700;
    color: #000;
    margin-bottom: 5px;
    line-height: 48px;
    margin: 0 24px;
}

.leisure-title-main-2 {
    font-size: 36px;
    color: #000;
    margin: 0 24px 36px;
    line-height: 44px;
    font-weight: 700;
}

/* ÅØ½ºÆ® ºí·Ï ±¸ºÐ¼± */
.leisure-divider {
    border: 0;
    border-top: 1px solid #ccc;
    width: 30px; /* ÂªÀº ¼±À¸·Î ÀÌ¹ÌÁö¿Í ºñ½ÁÇÏ°Ô Ç¥Çö */
    margin: 40px 0;
    text-align: left;
}

/* ¼ÒÁ¦¸ñ ½ºÅ¸ÀÏ */
.leisure-subtitle {
    font-size: 20px;
    font-weight: 800;
    color: #999;
    line-height: 27px;
}

.leisure-subtitle-2 {
    font-size: 20px;
    font-weight: 800;
    color: #000;
    margin-bottom: 5px;
    line-height: 27px;
}

/* º»¹® ½ºÅ¸ÀÏ */
.leisure-description {
    position:relative;
    color: #000;
    font-weight: 400;
    line-height: 21px;
    font-size: 13px;
}

.leisure-description:before {    content: "-";
    width: 16px;
    height: 3px;
    background: #000;
    display: block;
    font-size: 0;
    margin: 16px 0;
}
/* --- 4. Curriculum Section Styles --- */
.curriculum-section {    background-color: #FAFAFA;
    text-align: center;
    padding: 64px 24px;
}

.curriculum-korean {    font-size: 16px;
    color: #999;
    font-weight: 400;
    margin-bottom: 8px;
    line-height: 1;
}

.curriculum-title {
    font-size: 36px;
    font-weight: 700;
    margin-bottom: 40px;
    line-height: 40px;
    color: #000;
}
.curriculum-title img{
    width: 25px !important;
    vertical-align: middle;
    margin-top: -7px;
    margin-right: 8px;}

.curriculum-info {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-direction: column;
    align-items: center;
}

.curriculum-info .type{
    font-size: 16px;
    margin-bottom: 40px;
    line-height: 1;
    font-weight: 500;
    color: #000;}

.duration {
    font-weight: 700;
    color: #AD0F0A;
    font-size: 20px;
    line-height: 1;
}

.class-module {
    display: flex;
    flex-direction: column;
    padding: 40px 16px;
    border: 1px solid #ddd;
    background-color: #fff;
}

.module-header {
    margin-bottom: 30px;
    text-align: center;
}

.module-number {
    color: #fff;
    display: block;
    width: 96px;
    height: 26px;
    background: #000000;
    margin: 0 auto 26px;
    line-height: 26px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 32px;
    letter-spacing: 0;
}

.module-title {
    font-size: 22px;
    font-weight: 800;
    color: #000;
    display: inline-block;
}

.module-content {    display: flex;
    gap: 27px;
    flex-direction: column;
}

.module-details-container {    flex: 3;
    display: flex;
    gap: 8px;
    padding: 0;
    text-align: center;
}

.detail-box {    flex: 1;
    background-color: #fff;
    text-align: left;
    box-sizing: border-box;
}

.detail-box h4 {    font-size: 12px;
    font-weight: 700;
    color: #000;
    margin: 0 auto 16px;
    background: #EEEEEE;
    width: 61px;
    height: 26px;
    line-height: 26px;
    text-align: center;
    border-radius: 24px;
}

.detail-box h5 {    font-size: 18px;
    font-weight: 800;
    color: #000;
    margin-bottom: 12px;
    line-height: 25px;
    border-bottom: 1px solid #eee;
    padding-bottom: 12px;
    text-align: center;
}

.detail-box li {    font-size: 13px;
    color: #000;
    position: relative;
    line-height: 21px;
    text-align: center;
    font-weight: 400;
}

.detail-box li::before {
    content: '-';
    color: #000;
    font-weight: 400;
    display: none;
    width: 1em;
    margin-left: -1em;
}

.note {
    font-size: 12px;
    color: #000;
    margin-top: 18px;
    text-align: left;
    font-weight: 400;
    line-height: 24px;
}

/* --- 5. Contact Section Styles --- */
.contact-section {
    padding-top: 64px;
}

.section-divider-title {
    text-align: center;
    font-size: 20px;
    color: #000;
    margin-bottom: 32px;
    font-weight: 500;
    line-height: 1;
}

.grid-item.application{padding-top: 40px;}

.contact-grid {
    display: flex;
    justify-content: center;
    margin: 0 auto;
    background: #fff;
    flex-direction: column;
}
.grid-item.account{
    border-bottom: 0;
    margin-bottom: 40px;
    padding-bottom: 0;}
    

.grid-item.inquiry{
    position: relative;}
    
.grid-item {    flex: 1;
    margin: 0 24px 28px;
    text-align: center;
    background-color: #fff;
    border-bottom: 1px solid #DDDDDD;
    padding-bottom: 28px;
}


.grid-item.inquiry:before {
    content: "-";
    position: absolute;
    left: -41px;
    top: 0;
    width: 1px;
    height: 218px;
    background: #ddd;
    display: none;
    font-size: 0;
}

.grid-item.inquiry:after {
    content: "-";
    position: absolute;
    right: -41px;
    top: 0;
    width: 1px;
    height: 218px;
    background: #ddd;
    display: none;
    font-size: 0;
}

.grid-item h3 {    font-size: 22px;
    font-weight: 800;
    margin-bottom: 20px;
    color: #000;
    text-align: center;
    line-height: 1;
}

.item-divider {
    width: 24px;
    height: 3px;
    background-color: #000;
    margin: 32px 0;
}

.inquiry p, .account p {
    margin-bottom: 8px;
    font-size: 13px;
    line-height: 1;
    font-weight: 700;
    color: #000;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}
.inquiry p img, .account p img{width: 12px;margin-right:6px}

.inquiry p:nth-last-of-type(1) {margin-bottom:0}


/* --- 6. Space Guide Section Styles --- */
.naver-link {
    display: block;
    text-align: center;
}

.naver-link img{width:auto !important}

.space-guide-section {
    padding: 80px 24px 0;
    padding-bottom: 0;
}

.space-main-title {    font-size: 32px;
    font-weight: 700;
    padding-bottom: 16px;
    margin-bottom: 40px;
    color: #000;
    line-height: 1;
    border-bottom: 3px solid #000;
}

.space-guide-grid-text {    display: flex;
    margin-bottom: 40px;
    flex-direction: column;
    gap: 40px;
}


.space-item {}

.space-item-title {    font-size: 20px;
    font-weight: 700;
    margin-bottom: 16px;
    color: #000;
    vertical-align: middle;
    line-height: 1;
}

.space-item-title .icon {
    margin-right: 2px;
}

.space-item-title .icon img{
    vertical-align: top;
    margin-top: 2px;
    height: 17px;
    width: auto;}
    

.space-item ul {
    list-style: none;
    padding-left: 0;
}

.space-item li {    font-size: 13px;
    color: #000;
    position: relative;
    padding-left: 15px;
    line-height: 21px;
    font-weight: 400;
}

.space-item li::before {    content: '-';
    font-weight: bold;
    display: inline-block;
    width: 0.8em;
    margin-left: -1em;
}

/* °ø°£ ÄÁÅØ½ºÆ® »çÁø (´Ù¸ñÀû °ø°£ ¹× ±³À° »çÁø) */
.space-context-photos {    display: flex;
    gap: 8px;
    margin-bottom: 32px;
    flex-direction: column;
}


.space-guide-final-note {    padding-bottom: 80px;
    font-size: 13px;
    color: #000;
    line-height: 22px;
    text-align: left;
}

/* --- 7. Event Photos Section Styles --- */
.event-photos-section {
    margin: 0 24px 64px;
}

.event-photos-section h2 {    font-size: 32px;
    font-weight: 700;
    color: #000;
    line-height: 1;
    padding-bottom: 16px;
    margin-bottom: 40px;
    border-bottom: 3px solid #000;
}

.event-photo-grid {    gap: 8px;
    display: flex;
    flex-direction: column;
}

.event-photo-grid .image-placeholder {}

.event_btn{
    margin: 80px auto -24px;
    text-align: center;
    display: block;}
/* BASIC css end */

