  :root {
    --ra-primary: #0078ff;
    --ra-primary-dark: #005bc2;
    --ra-primary-light: #f0f7ff;
    --ra-primary-hover: #e0efff;
    --ra-border: #d2d6e0;
    --ra-text-main: #333333;
    --ra-text-muted: #666666;
    --ra-bg-gray: #f0f2f5;
    --ra-navy: #1a2b56;
    --ra-gold: #b39352;
    --ra-navy-light: #f4f6fa;
    --ra-gold-light: #fbf9f4;
    --ra-border: #d2d6e0;
    --ra-text-main: #333333;
    --ra-text-muted: #666666;
    --ra-bg-gray: #f0f2f5;
    --ra-fee-tab1: #7ce3ea;
    --ra-fee-tab2: #24a1b8;
    --ra-fee-tab3: #114c72;
    --ra-fee-tab4: #082142;
    --ra-fee-title: #0c4785;
    --ra-fee-text: #333333;
    --ra-fee-text-sub: #777777;
    --ra-fee-border: #f0f0f0;
  }
/**************
애니메이션
**************/
@keyframes swing {
    0% { transform: rotate(-12deg) }
    50% { transform: rotate(12deg) }
    100% { transform: rotate(-12deg) }
}
@keyframes gradientBG {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
@keyframes floating {
    0% { transform: translateY(0px); }
    50% { transform: translateY(-15px); }
    100% { transform: translateY(0px); }
}
@keyframes fadeUp {
    from{opacity:0;transform:translateY(-10vh) scale(0.95)}
    to{opacity:1;transform:translateY(-10vh) scale(1)}
}
@keyframes slideUpTicket {
    from{opacity:0;transform:translate(-50%,50px)}
    to{opacity:1;transform:translate(-50%,0)}
}
@keyframes fadeIn {
    from{opacity:0;transform:translateY(20px)}
    to{opacity:1;transform:translateY(0)}
}
/*스크롤픽스*/
html{scroll-padding-top: 70px !important; scroll-behavior: smooth}
.container-custom > section { scroll-margin-top: 0 !important; }
.container-custom > section:not(.has-sticky) { overflow: hidden; }

/* 모바일 환경을 위한 미디어 쿼리 */
@media (max-width: 992px) {
    html { scroll-padding-top: 60px !important; }
    html, body { overflow: initial !important; }
    section[id] { scroll-margin-top: 0 !important; }
    .admin-bar body { margin-top: 46px; }
}
/***************
SWIPER
***************/
/* 공통 네비게이션 버튼 스타일 */
.swiper-button-next:not(.promotion-arrow), 
.swiper-button-prev:not(.promotion-arrow){
    width: 48px !important;
    height: 48px !important;
    background:var(--primary) !important;
    border: 1px solid rgba(0, 0, 0, 0.05);
    border-radius: 50% !important;
    color:  rgba(255, 255, 255, 0.95);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    z-index: 20 !important;
}
.swiper-button-next:after,.swiper-button-prev:after { font-size: 1.1rem !important; font-weight: 900 !important}
.swiper-button-next:hover,.swiper-button-prev:hover { background: var(--primary) !important; color: #fff !important; box-shadow: 0 12px 24px rgba(2, 132, 199, 0.3) !important}
.swiper-button-disabled { opacity: 0 !important; pointer-events: none !important}
/***************
***************/
.prd-sl .gspb-slider__inner { max-height: none !important; height: 450px; }
.prd-sl img { object-fit: cover; width: 100% !important; height: 100% !important; top: 0; left: 0; aspect-ratio: 1 / 1; }
/***************
타이포::템플릿
***************/
.landing-page .container{width:100%;padding:0}
.landing-page .container-custom>section:not(.mainVis),
.landing-page .container-custom .entry-content>section:not(.mainVis),
.container-custom>.section:not(.mainVis),#main>.section:not(.mainVis),
.landing-page #main .entry-content>section:not(.mainVis){width:100%;max-width:100%;padding:100px 0;position:relative;margin:0 auto}
.container-section{max-width:1200px;margin:0 auto;width:100%}
.landing-page .container-section ul li{color:#000;font-size:24px;font-weight:500;list-style:none;line-height:1.3;padding-left:0;padding-bottom:12px;position:relative}
.landing-page .container-section ul:not(.square-check):not(.check-mark) li{padding-left:19px}
.landing-page .container-section ul:not(.square-check):not(.check-mark) li::before{content:'';display:block;width:6px;height:6px;background:#000;border-radius:100%;position:absolute;top:12px;left:0}
.landing-page h1,.landing-page h2,.landing-page h3,.landing-page h4,.landing-page h5,.landing-page h6,.landing-page p{color:#222;letter-spacing:-0.034em}
.landing-page p{margin-block-start:0}
.landing-page h1{font-size:63px;line-height:1.75;margin-top:0;margin-bottom:0}
.landing-page h2{font-size:56px;line-height:1.25;margin-top:0;margin-bottom:0}
.landing-page h3{font-size:36px;line-height:1.35;margin-top:0;margin-bottom:0}
.landing-page h4{font-size:30px;line-height:1.4;margin-top:0;margin-bottom:0}
.landing-page h5{font-size:24px;line-height:1.35;margin-top:0;margin-bottom:0}
.landing-page h6{font-size:20px;line-height:1.25;margin-top:0;margin-bottom:0}
.landing-page p{font-size:20px;letter-spacing:.038em;line-height:1.5;font-weight:500}
.landing-page ul{padding-left:0}
.section-title{text-align:center}
.section-title span { color: var(--primary); }
.section-desc { font-size: 1.2rem; color: var(--text-muted); word-break: keep-all; }
@media(max-width:992px) {
    .landing-page h3{font-size:24px}
    .landing-page h4{font-size:20px}
    .landing-page p{font-size:16px}
    .box-1{padding:24px 14px}
    .wp-child-theme-blocksy-royal .mainVis{padding-top:40px}
}
@media (max-width:768px) {
    #main-container .section-title { font-size: 2rem }
    #main-container .section-desc { font-size: 1rem; }
}
/*************
헤더
*************/
.wp-child-theme-blocksy-royal .header-landing {transition: all ease .3s;left: 0; width: 100%; z-index: 99}
.wp-child-theme-blocksy-royal .header-landing [data-row*=middle] { background: transparent}
.wp-child-theme-blocksy-royal .header-landing [data-row]>div { min-height: 90px !important}
.wp-child-theme-blocksy-royal.desk_scrolling .header-landing { background: #fff; position: sticky; transition: all ease .3s}
/*.desk_scrolling .header-landing.ct-header { position: sticky; top: 0; left: 0; width: 100%; background: #fff}*/
.admin-bar:not(.desk_scrolling) .header-landing{ top: 0}
.admin-bar.desk_scrolling .header-landing{ top: 32px}
.ct-header-text,.ct-header-text>div,.ct-header-text>div>div { height: 100%}
.desk_scrolling .header-landing { top: 32px}
.header-landing { display: flex; justify-content: center; align-items: center; height: 60px; width: 100%; position: relative; transition: all ease .3s; top: 0; z-index: 999}
.wp-child-theme-blocksy-royal .header-landing { background: #fff}
#main-container .section-header { text-align: center; margin-bottom: 3rem; }
#main-container .section-badge {display: inline-block;background: rgba(30, 58, 138, 0.1); color: var(--primary); font-weight: 700; padding: 0.5rem 1.2rem; border-radius: 50px; font-size: 0.9rem; margin-bottom: 1rem; letter-spacing: 1px; }
@media(min-width:993px) {
    .admin-bar.wp-child-theme-blocksy-royal.desk_scrolling .header-landing{ top: 32px; transition: all ease .3s }
}
.admin-bar header.is-stuck+main .header-landing{position:sticky;z-index:9;top:32px}
.desk_scrolling.wp-child-theme-blocksy-royal .header-landing{position:sticky}
body:not(.admin-bar).desk_scrolling.wp-child-theme-blocksy-royal .header-landing { top: 0}
@media(min-width:993px) {
    .admin-bar.desk_scrolling.wp-child-theme-blocksy-royal .header-landing{top:32px}
}
@media(max-width:992px) {
    .admin-bar header.is-stuck+main .header-landing{top:0}
    .landing-page .main-header { position: sticky !important; width: 100% !important; top: 0 !important; left: 0 !important; z-index: 1000 !important }
    .navbar-header { height: 60px }
    main:not(.site-main) .container-custom { margin-top: 60px }
    .landing-page .container-custom>section,main>section { padding:30px 0 !important }
    .admin-bar.desk_scrolling .header-landing.ct-header { top: 0 }
    .wp-child-theme-blocksy-royal.admin-bar.desk_scrolling.wp-child-theme-blocksy-royal{ position: sticky; top: 60px; left: 0; z-index: 99 }
    .header-landing { background: #fff; text-align: center; height: 52px; width: 100%; border-top: 1px solid #ddd; white-space: nowrap; overflow-x: auto; overflow-y: hidden; -webkit-overflow-scrolling: touch; -ms-overflow-style: -ms-autohiding-scrollbar; margin-bottom: 0 !important }
    .header-landing { justify-content: start; padding-left: 12px }
}
/* ==========================================
   🏰 Royal Landing Nav Styles (Premium Glassmorphism)
   ========================================== */
.landing-page .site-header.is-stuck{height:0;display:none;transition:all ease .3s}
.header-landing{position:sticky;top:0;width:100%;z-index:1000;transition:all .3s cubic-bezier(0.4,0,0.2,1)}
.desk_scrolling .royal-nav{background:#ffffffe6;padding:8px 0}
#royal-nav,.royal-nav { display: flex; justify-content: center; align-items: center; gap: 20px; height: 100%; background: #ffffffbf; backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); border-bottom: 1px solid #ffffff4d; padding: 12px 0; box-shadow: 0 4px 30px #0000000d; }
.royal-nav > a{ display: flex; align-items: center; height: 100%; text-decoration: none; color: #222;font-size:14px;font-weight:600; padding:10px 10px;transition: all 0.3s ease; white-space:nowrap;letter-spacing:-0.02em}
.royal-nav > a:hover{ background:var(--ivory);color:inherit}
#royal-nav a:last-child{background-color:var(--c1);color:#fc0!important;padding:12px 13px;border-radius:10px;height:calc(100% - 12px)}
@media (max-width: 992px) {
    .royal-nav{gap:10px;padding:8px 15px;justify-content:start}
    .royal-nav a{font-size:14px;padding:6px 14px}
}
/*************
푸터
*************/
.footer-custom{background:#f5f5f5;padding:60px 20px 120px}
.footer-custom>.container{max-width:1200px;margin:0 auto;width:100%}
.footer-custom p{font-size:14px;color:#777;margin-bottom:0;text-align:center}
@media(max-width:992px) {
    .footer-custom { padding: 20px 14px 80px }
    .footer-custom p { font-size: 14px !important }
}
/****************
레이아웃
*****************/
main .card-hori .item h3{font-size:24px}
main .card-hori .item h4,.number-card .item .num span{font-size:18px}
main .card-hori .item p{font-size:16px}
main .container-section{padding:0 20px}
main .section-title h5{font-size:20px}
.card-type-2 .item { background: #ffff; border-radius: 12px; border: 1px solid #dedede; margin-bottom: 24px; padding: 60px 80px; position: relative}
.card-hori.cols-2{/*flex-direction:column;*/gap:12px!important}
@media(max-width:767px){
    main .container-section{padding:0 12px}
}
/***********
카드
***********/
/*통계카드*/
.stat-card{background:var(--surface);border-radius:32px;padding:3.5rem 2rem;text-align:center;box-shadow:0 20px 40px #0000000a;border:1px solid #00000005;transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}
.stat-card::after{content:'';position:absolute;width:150px;height:150px;background:var(--summer-light);border-radius:50%;top:-50px;right:-50px;z-index:0;opacity:.5;transition:transform .5s ease}
.stat-card:hover{transform:translateY(-5px);box-shadow:0 30px 50px #0284c714}
.stat-card:hover::after{transform:scale(1.2)}
.stat-content{position:relative;z-index:1}
.stat-label{font-size:1.2rem;font-weight:700;color:var(--text-muted);margin-bottom:1rem;display:block}
.stat-number-wrapper{display:flex;align-items:baseline;justify-content:center;gap:.2rem}
.stat-number{font-size:4.5rem;font-weight:900;color:var(--summer-blue);line-height:1;letter-spacing:-2px}
/*리스트카드*/
.showcase-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:4rem;align-items:start}
.list-column{display:flex;flex-direction:column;gap:1.5rem}
.list-item{background:var(--surface);border:2px solid transparent;border-radius:24px;padding:2.5rem;cursor:pointer;transition:all .3s cubic-bezier(0.16,1,0.3,1);box-shadow:0 10px 25px #00000008;position:relative;overflow:hidden}
.list-item:hover{transform:translateX(10px);border-color:#0284c733}
.list-item.active{border-color:var(--summer-blue);background:var(--surface);box-shadow:0 20px 40px #0284c71a;transform:translateX(15px)}
.list-item::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--summer-blue);transition:width .3s ease}
.list-item.active::before{width:8px}
.item-title{font-size:1.6rem;font-weight:800;color:var(--text-main);margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;transition:color .3s ease}
.list-item.active .item-title{color:var(--summer-blue)}
.item-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--summer-light);color:var(--summer-blue);border-radius:50%;font-size:1.2rem;font-weight:900}
.list-item.active .item-number{background:var(--summer-blue);color:#fff}
.item-desc-list{list-style:none;display:flex;flex-direction:column;gap:.8rem;margin-top:12px}
.item-desc-list li{position:relative;padding-left:2rem;font-size:1.1rem!important;line-height:1.5;color:var(--text-muted);font-weight:500;word-break:keep-all;padding-bottom:0!important}
.item-desc-list li::before{content:'✓';position:absolute;left:0;top:2px;display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#ecfdf5;color:#10b981;border-radius:50%;font-size:.8rem;font-weight:900}
.image-column{position:sticky;top:120px;width:100%;height:650px;border-radius:32px;overflow:hidden;box-shadow:0 30px 60px #0000001a}
.showcase-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transform:scale(1.05);transition:opacity .6s ease,transform 4s ease-out;z-index:1}
.showcase-img.active{opacity:1;transform:scale(1);z-index:2}
@media (max-width: 992px) {
    .showcase-grid{grid-template-columns:1fr;gap:2rem}
    .image-column{position:relative;top:0;height:400px;border-radius:24px;order:-1}
    .list-item{padding:2rem}
    .list-item:hover,.list-item.active{transform:translateX(0)}
}
@media (max-width: 480px) {
    .image-column{height:300px}
    .item-title{font-size:1.4rem}
    .item-desc-list li{font-size:1rem}
    .list-item{padding:1.5rem}
}
/**************
프라이싱테이블
**************/
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-bottom:4rem;align-items:center}
.pricing-card{background:var(--surface);border-radius:32px;padding:3rem 2rem;text-align:center;box-shadow:0 15px 35px #0000000a;border:1px solid #0000000d;transition:transform .4s ease,box-shadow .4s ease;position:relative;overflow:hidden;opacity:0;transform:translateY(30px)}
.pricing-card.visible{opacity:1;transform:translateY(0)}
.pricing-card:hover{transform:translateY(-10px);box-shadow:0 25px 50px #0284c71a;border-color:#0284c733}
.pricing-card.popular{padding:4rem 2rem;border:2px solid var(--summer-blue);box-shadow:0 20px 40px #0284c726;z-index:1}
.pricing-card.popular .card-header{color:var(--primary)}
.popular-badge{position:absolute;top:0;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:.5rem 1.5rem;border-bottom-left-radius:16px;border-bottom-right-radius:16px;font-weight:800;font-size:.9rem;letter-spacing:1px}
.card-header{font-size:1.5rem;font-weight:800;color:var(--text-main);margin-bottom:1.5rem}
.discount-badge{display:inline-block;background:#fff7ed;color:#ea580c;padding:.4rem 1rem;border-radius:8px;font-weight:800;font-size:.95rem;margin-bottom:1rem;border:1px solid #ffedd5}
.original-price{font-size:1.1rem;color:#94a3b8;text-decoration:line-through;font-weight:600;margin-bottom:.2rem}
.final-price{display:flex;align-items:baseline;justify-content:center;gap:.2rem;margin-bottom:1rem}
.final-price .number{font-size:3.5rem;font-weight:900;color:var(--primary);line-height:1;letter-spacing:-1px}
.final-price .unit{font-size:1.2rem;font-weight:700;color:var(--text-main)}
.status-badge{font-size:.9rem;color:var(--text-muted);font-weight:600;background:#f1f5f9;padding:.3rem 1rem;border-radius:50px;display:inline-block}
.details-box{background:var(--surface);border-radius:24px;padding:2.5rem;box-shadow:0 15px 35px #00000008;margin-bottom:4rem;display:flex;flex-direction:column;gap:1.5rem;opacity:0;transform:translateY(20px)}
.details-box.visible{opacity:1;transform:translateY(0);transition:all .6s ease}
.detail-row{display:flex;align-items:flex-start;gap:1.5rem}
.detail-label{display:flex;align-items:center;gap:.5rem;min-width:100px;font-weight:800;font-size:1.1rem}
.label-inc{color:#059669}
.label-exc{color:#e11d48}
.detail-content{font-size:1.05rem;line-height:1.6;color:var(--text-main);font-weight:500;word-break:keep-all}
.detail-content strong{color:var(--primary)}
.table-container{background:var(--surface);border-radius:24px;overflow:hidden;box-shadow:0 15px 35px #0000000a;border:1px solid var(--border-color);opacity:0;transform:translateY(20px)}
.table-container.visible{opacity:1;transform:translateY(0);transition:all .6s ease .2s}
.table-header-title{background:var(--primary);color:#fff;padding:1.5rem 2rem;font-size:1.4rem;font-weight:800;display:flex;align-items:center;gap:.8rem}
.fees-table{width:100%;border-collapse:collapse;text-align:left}
.fees-table th{background:#f8fafc;padding:1.2rem 2rem;font-weight:700;color:var(--text-muted);border-bottom:2px solid var(--border-color)}
.fees-table td{padding:1.2rem 2rem;font-weight:600;color:var(--text-main);border-bottom:1px solid #f1f5f9;vertical-align:top}
.fees-table tr:last-child td{border-bottom:none}
.fees-table tr:hover td{background:#f8fafc}
.td-price{color:var(--primary);font-weight:800!important;white-space:nowrap}
.td-note{color:var(--text-muted);font-weight:500!important;font-size:.95rem}
.visa-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;font-size:.95rem}
.visa-list li{display:flex;justify-content:space-between;background:#fff;border:1px solid #e2e8f0;padding:.4rem .8rem;border-radius:6px}
@media (max-width: 992px) {
    .pricing-grid{grid-template-columns:1fr;gap:2rem}
    .pricing-card{padding:3rem 2rem}
    .pricing-card.popular{padding:3.5rem 2rem;transform:scale(1)}
    .pricing-card:hover{transform:translateY(-5px)}
    .visa-list{grid-template-columns:1fr}
}
@media (max-width: 768px) {
    .final-price .number{font-size:3rem}
    .detail-row{flex-direction:column;gap:.5rem}
    .details-box{padding:1.5rem}
    .table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}
    .fees-table th,.fees-table td{padding:1rem}
}
/**/
.card-hori { display: flex; gap: 30px; width: 100%; margin: 0 auto 30px; flex-wrap: wrap; margin-top: 60px}
.card-hori .item { display: flex; flex-direction: column; background: #fff; padding: 17px 7px; border: 1px solid #d0d0d0; border-radius: 12px; flex: 1}
.cols-2 .item { width: calc(50% - 15px); min-width: calc(50% - 15px)}
.cols-3 .item { width: calc(33.3333% - 20px); min-width: calc(33.3333% - 20px)}
.card-hori .item h4 {font-size: 22px; color: var(--c1); margin-top: 10px; margin-bottom: 5px}
.card-hori .item p {font-size: 20px; line-height: 1.5; margin-bottom: 0; font-weight: 600}
@media(max-width:992px){
    .card-type-2 .item { padding: 30px 20px }
    .card-hori .item { height: auto !important; flex: none !important; width: 100%; padding: 30px 20px }
}
/***************
컬럼
***************/
.cols { display: flex; justify-content: space-between; gap: 30px; width: 100%}
.cols>div { flex: 1; display: flex; overflow: hidden}
.cols-2-tra { display: flex; flex-direction: row; gap: 24px; flex-wrap: wrap}
.cols-2-tra .card { position: relative; border-radius: 30px; overflow: hidden; display: flex; flex: 0 0 calc(50% - 12px)}
.cols-2-tra .card .banner { position: absolute; top: 0; right: 0; z-index: 1}
.cols-2-tra .card h4 { background: #000000b3; color: #fff; justify-content: center; text-align: center; position: absolute; bottom: 0; width: 100%; display: flex; flex: 1}
.cols-2-tra .card img { width: 100%; height: 100%; object-fit: cover}
@media(max-width:992px) {
    .cols { flex-direction: column }
    .cols-2-tra .card { flex: 0 0 100%; border-radius: 8px }
}
/**/
.number-card .item { padding: 30px 40px; background-color: var(--c9)}
.number-card .item .num { display: flex; margin-bottom: 32px; align-items: center}
.number-card .item .num span { background: var(--c1); color: #fff; width: 42px; height: 42px; display: flex; border-radius: 8px; justify-content: center; align-items: center; margin-right: 12px}
@media(max-width:992px){
    .number-card .item .num span { width: 32px; height: 32px; }
}
/**************
아코디언(교재)
**************/
.tab-container{display:flex;flex-direction:column;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}
.tab-buttons{display:flex;justify-content:center;gap:10px}
.tab-btn{background:var(--surface);border:2px solid var(--border-color);color:var(--text-muted);padding:.8rem 2rem;border-radius:50px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #00000005}
.tab-btn:hover{border-color:var(--summer-blue);color:var(--primary)}
.tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 10px 20px #0284c733;transform:translateY(-2px)}
.sub-tabs{ display: flex; flex-direction: column}
.sub-pane{padding: 0 40px}
.books-wrapper{position:relative;min-height:400px;width:100%}
.books-grid{display:none;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:2rem;animation:fadeIn .5s ease forwards}
.books-grid.active{display:grid!important}
.book-card{background:var(--surface);border-radius:20px;padding:1.5rem;text-align:center;border:1px solid var(--border-color);box-shadow:0 10px 20px #00000008;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;cursor:pointer}
.book-card:hover{transform:translateY(-10px);box-shadow:0 20px 40px #00000014;border-color:var(--summer-blue)}
.book-cover{width:100%;aspect-ratio:3 / 4;border-radius:8px;overflow:hidden;margin-bottom:1.5rem;box-shadow:5px 5px 15px #0000001a;position:relative}
.book-cover::after{content:'';position:absolute;left:0;top:0;height:100%;width:4px;background:linear-gradient(to right,#fff9,#0000001a)}
.book-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.book-card:hover .book-cover img{transform:scale(1.05)}
.book-level{font-size:.8rem;font-weight:800;color:var(--summer-blue);background:#0ea5e91a;padding:.2rem .8rem;border-radius:4px;margin-bottom:.5rem;text-transform:uppercase}
.book-title{font-size:1.1rem;font-weight:700;color:var(--text-main);line-height:1.4;word-break:keep-all}
@media (max-width: 768px) {
    .tab-buttons{padding:0 12px}
    .tab-btn{padding:12px 16px;font-size:.85rem}
    .tab-content{padding:24px 18px}
    .tab-container{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding-bottom:1rem;-webkit-overflow-scrolling:touch;scrollbar-width:none}
    .tab-container::-webkit-scrollbar{display:none}
    .tab-btn{white-space:nowrap;font-size:1rem;padding:.6rem 1.5rem}
    .books-grid{grid-template-columns:repeat(2,1fr);gap:1rem}
    .book-card{padding:1rem;border-radius:16px}
    .book-title{font-size:.95rem}
    .book-level{font-size:.75rem}
}
/**************
UL, LI
**************/
.nolist,.nolist li { list-style: none !important}
.nolist li::before { display: none !important}
.check { display: flex; flex-direction: column; align-items: start}
.check h5 { position: relative; padding-left: 40px}
.check h5::before { content: '🗸'; position: absolute; top: 3px; left: 0; font-size: 28px; color: var(--c1)}
.check p { padding-left: 41px; margin-top: 9px; font-size: 23px}
.check h5::before{font-size:20px}
.check h5{padding-left:20px;font-size:20px}
.check p{padding-left:0;text-align:left;line-height:1.2}
.check-mark { display: flex; flex-direction: row}
.check-mark li { display: flex; flex-direction: row; align-items: center; gap: 12px}
.check-mark li::before { content: '🗸'; background: transparent; top: 0; margin-right: 5px; position: absolute; top: 0; left: 0}
.sub-list{margin-top:8px;margin-left:32px;list-style:disc;color:#334155}
.sub-list li{margin-bottom:8px}
.note{background:#fef9e3;padding:12px 16px;border-radius:12px;font-size:.9rem;color:#92400e;margin-top:20px}
ul.square-check { padding-left: 0}
ul.square-check li { padding-left: 39px !important; list-style: none !important; position: relative}
ul.square-check li::before { content: '✅'; background: transparent; top: 0; margin-right: 5px; position: absolute; top: 0; left: 0}
ul.inline-ul { display: flex; flex-direction: row}
@media (min-width:993px) {
}
@media(max-width:992px) {
    .landing-page .container-section ul li { font-size: 18px }
    .landing-page .container-section ul:not(.square-check):not(.check-mark) li::before { top: 10px !important; left: 4px }
    ul.inline-ul { flex-direction: column }
    ul.square-check li { padding-left: 26px !important }
}
/*********
비교표
*********/
.comparison-table{display:grid;grid-template-columns:140px 1fr 1.2fr;position:relative;background:var(--surface);border-radius:24px;box-shadow:0 10px 30px #00000008;border:1px solid var(--border-color)}
.table-header{display:contents}
.th-cell{padding:2rem 1.5rem;font-weight:800;font-size:1.2rem;text-align:center;border-bottom:2px solid var(--border-color)}
.th-category{color:var(--text-muted);font-size:1rem}
.th-competitor{background:var(--competitor-bg);color:var(--text-muted);border-top-left-radius:24px}
.th-royal{background:var(--primary);color:#fff;font-size:1.5rem;border-top-right-radius:24px;position:relative;box-shadow:0 -10px 20px #1e3a8a33;transform:scale(1.02) translateY(-5px);z-index:10;border-bottom:none}
.th-royal i{color:#fde047;margin-right:8px}
.table-row{display:contents}
.td-cell{padding:1.8rem 1.5rem;border-bottom:1px solid #f1f5f9;font-size:1.05rem;line-height:1.6}
.table-row:last-child .td-cell{border-bottom:none}
.td-category{font-weight:800;color:var(--text-main);text-align:center;display:flex;align-items:center;justify-content:center;background:var(--surface)}
.td-competitor{background:var(--competitor-bg);color:#64748b;font-weight:500}
.td-competitor ul,.td-royal ul{list-style:none}
.td-competitor li{position:relative;padding-left:1.5rem;margin-bottom:.8rem}
.td-competitor li:last-child{margin-bottom:0}
.td-competitor li::before{content:'\f00d';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:0;color:#94a3b8;font-size:.9rem}
.td-royal{background:#fff;color:var(--text-main);font-weight:700;position:relative;z-index:5;box-shadow:10px 0 20px #0000000d -10px 0 20px #00000005;transform:scale(1.02);border-left:2px solid var(--primary);border-right:2px solid var(--primary)}
.table-row:last-child .td-royal{border-bottom-right-radius:24px;border-bottom-left-radius:8px;border-bottom:2px solid var(--primary);padding-bottom:2.5rem}
.td-royal li{position:relative;padding-left:1.8rem;margin-bottom:1rem;word-break:keep-all}
.td-royal li:last-child{margin-bottom:0}
.td-royal li::before{content:'\f00c';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;left:0;color:var(--primary);font-size:1.1rem}
.td-royal li strong{color:var(--primary)}
.highlight-text{background:linear-gradient(120deg,#d9770633 0%,#d9770633 100%);background-repeat:no-repeat;background-size:100% 40%;background-position:0 88%;color:#b45309}
@media (max-width: 992px) {
    .comparison-table{grid-template-columns:1fr;border:none;box-shadow:none;background:transparent;gap:2rem}
    .table-header{display:none}
    .table-row{display:flex;flex-direction:column;background:var(--surface);border-radius:24px;overflow:hidden;box-shadow:0 10px 20px #0000000d}
    .td-category{padding:1.2rem;background:var(--primary);color:#fff;border-radius:0;justify-content:flex-start;font-size:1.2rem}
    .td-competitor{padding:1.5rem;border-radius:0}
    .td-competitor::before{content:'타 필리핀 어학원';display:block;font-size:.85rem;font-weight:800;color:#94a3b8;margin-bottom:.8rem}
    .td-royal{padding:1.5rem;transform:scale(1);box-shadow:none;border:none;border-top:1px dashed var(--border-color);background:#f8fafc}
    .table-row:last-child .td-royal{border-radius:0;padding-bottom:1.5rem;border-bottom:none}
    .td-royal::before{content:'👑 로얄아카데미';display:block;font-size:1rem;font-weight:800;color:var(--primary);margin-bottom:1rem}
}
@media (max-width: 480px) {
    .td-cell{padding:1.2rem;font-size:1rem}
}
/*************
일정테이블
*************/
.schedule-grid{display:grid;grid-template-columns:1fr 3fr;gap:2rem;align-items:start}
.schedule-grid-h{ display: flex; flex-direction: column; gap: 3rem;}
.timeline-card{background:var(--surface);border-radius:24px;padding:3rem 2.5rem;box-shadow:0 15px 35px #00000008;border:1px solid var(--border-color)}
.card-title{font-size:1.5rem;font-weight:800;color:var(--text-main);margin-bottom:2rem;display:flex;align-items:center;gap:.8rem}
.card-title i{color:var(--summer-blue)}
.timeline-list{position:relative;padding-left:1.5rem}
.timeline-list::before{content:'';position:absolute;top:10px;bottom:10px;left:0;width:2px;background:#e2e8f0}
.timeline-list .timeline-item{position:relative;padding-bottom:1.5rem;padding-left:1.5rem}
.timeline-list .timeline-item:last-child{padding-bottom:0}
.timeline-list .timeline-item::before{content:'';position:absolute;left:-1.5rem;top:5px;width:14px;height:14px;background:var(--surface);border:3px solid var(--primary);border-radius:50%;transform:translateX(-5px)}
.horizontal-timeline-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:1.5rem;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}
.horizontal-timeline-wrapper::-webkit-scrollbar{height:8px}
.horizontal-timeline-wrapper::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:10px}
.horizontal-timeline{display:flex;position:relative;min-width:max-content;align-items:flex-start;padding-top:10px}
.h-timeline-item{display:flex;flex-direction:column;align-items:center;position:relative;width:110px}
.h-timeline-item::after{content:'';position:absolute;top:7px;left:50%;width:100%;height:2px;background:#e2e8f0;z-index:0}
.h-timeline-item:last-child::after{display:none}
.h-dot{width:16px;height:16px;background:var(--surface);border:3px solid var(--primary);border-radius:50%;position:relative;z-index:1;margin-bottom:1.2rem}
.h-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem}
.h-time{font-size:.85rem;font-weight:700;color:var(--primary);background:#f0f9ff;padding:.4rem .8rem;border-radius:8px;line-height:1.4}
.h-period{font-size:1.1rem;font-weight:800;color:var(--text-main);margin-top:.2rem}
.h-subject{font-size:.9rem;font-weight:600;color:var(--text-muted);word-break:keep-all}
.h-timeline-item.lunch-break .h-dot{border-color:var(--summer-coral);background:var(--summer-coral);box-shadow:0 0 10px #fb923c66}
.h-timeline-item.lunch-break .h-time{color:#ea580c;background:#ffedd5}
.h-timeline-item.lunch-break .h-period{color:#ea580c}
.time-badge{display:inline-block;font-size:.85rem;font-weight:700;color:var(--primary);background:#0284c71a;padding:.2rem .6rem;border-radius:6px;margin-bottom:.3rem;font-variant-numeric:tabular-nums}
.subject{font-size:1.1rem;font-weight:700;color:var(--text-main)}
.subject-desc{font-size:.9rem;color:var(--text-muted);margin-left:.5rem;font-weight:500}
.timeline-list .timeline-item.lunch-break::before{border-color:var(--summer-coral);background:var(--summer-coral);box-shadow:0 0 10px #fb923c66}
.timeline-list .timeline-item.lunch-break .time-badge{color:#ea580c;background:#ffedd5}
.timeline-list .timeline-item.lunch-break .subject{color:#ea580c}
.table-card{background:var(--surface);border-radius:24px;padding:3rem 0;box-shadow:0 15px 35px #00000008;border:1px solid var(--border-color);overflow:hidden}
.table-header-area{padding:0 2.5rem;margin-bottom:2rem;display:flex;justify-content:space-between;align-items:center}
.swipe-hint{display:none;font-size:.85rem;color:var(--text-muted);background:#f1f5f9;padding:.3rem .8rem;border-radius:50px}
.table-responsive-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 2.5rem}
.styled-table{width:100%;min-width:650px;border-collapse:separate;border-spacing:0}
.styled-table th,.styled-table td{padding:1.2rem 1rem;text-align:center;border-bottom:1px solid #f1f5f9;font-size:.95rem}
.styled-table th{background:var(--primary);color:#fff;font-weight:700;letter-spacing:1px;font-size:1rem}
.styled-table th:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}
.styled-table th:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}
.styled-table td:first-child{font-weight:800;color:var(--text-main);background:#f8fafc;border-top-left-radius:8px;border-bottom-left-radius:8px;font-variant-numeric:tabular-nums}
.styled-table td{color:var(--text-muted);font-weight:600;transition:background .2s}
.styled-table tr:hover td{background:#f8fafc}
.styled-table th:nth-child(6){background:var(--summer-coral)}
.styled-table td:nth-child(6){background:#fff7ed;color:#c2410c;font-weight:700;border-top-right-radius:8px;border-bottom-right-radius:8px}
.styled-table tr:hover td:nth-child(6){background:#ffedd5}
@media (max-width: 1024px) {
    .schedule-grid{grid-template-columns:1fr;gap:3rem}
    .table-card{padding:2.5rem 0}
}
@media (max-width: 768px) {
    .timeline-card{padding:2.5rem 1.5rem}
    .table-header-area{padding:0 1.5rem;flex-direction:column;align-items:flex-start;gap:1rem}
    .table-responsive-wrapper{padding:0 1.5rem}
    .swipe-hint{display:inline-flex;align-items:center;gap:.5rem}
    .timeline-item{padding-bottom:1.2rem}
    .subject{font-size:1rem}
    .time-badge{font-size:.8rem}
}
/*********************
갤러리
*********************/
.gallery-container{background:var(--surface);border-radius:32px;padding:3rem;box-shadow:0 25px 50px -12px #0000000d;border:1px solid #00000008}
.gallery-tabs{display:flex;gap:1rem;margin-bottom:2rem;justify-content:center;flex-wrap:wrap}
.tab-btn{background:#f1f5f9;border:none;color:var(--text-muted);padding:.8rem 2rem;border-radius:50px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease}
.tab-btn:hover{background:#e2e8f0;color:var(--text-main)}
.tab-btn.active{background:var(--primary);color:#fff;box-shadow:0 10px 20px #0284c733;transform:translateY(-2px)}
.viewer-main{position:relative;width:100%;height:500px;border-radius:24px;overflow:hidden;margin-bottom:1.5rem;background:#e2e8f0;box-shadow:0 15px 35px #0000000d;cursor:pointer}
.viewer-main img{width:100%;height:100%;object-fit:cover;object-position:center;transition:opacity .4s ease,transform .8s ease;opacity:0;transform:scale(1.02)}
.viewer-main img.loaded{opacity:1;transform:scale(1)}
.btn-expand-modal{position:absolute;bottom:1.5rem;right:1.5rem;background:#0f172ab3;backdrop-filter:blur(8px);color:#fff;padding:.8rem 1.5rem;border-radius:50px;font-size:1rem;font-weight:700;border:1px solid #fff3;display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .3s ease;z-index:10}
.btn-expand-modal:hover{background:#0f172ae6;transform:scale(1.05)}
.category-info-overlay{position:absolute;top:1.5rem;left:1.5rem;background:#ffffffe6;backdrop-filter:blur(8px);padding:1rem 1.5rem;border-radius:16px;box-shadow:0 10px 20px #0000001a;z-index:10;max-width:400px}
.category-info-overlay h3{font-size:1.3rem;font-weight:800;color:var(--primary);margin-bottom:.3rem}
.category-info-overlay p{font-size:.95rem;font-weight:600;color:var(--text-muted);margin:0}
.viewer-thumbs-wrapper{position:relative}
.viewer-thumbs{display:flex;gap:12px;overflow-x:visible;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding-bottom:1rem;scrollbar-width:none}
.viewer-thumbs::-webkit-scrollbar{display:none}
.thumb-item{flex:0 0 120px;height:80px!important;border-radius:12px;overflow:hidden;cursor:pointer;border:3px solid transparent;opacity:.6;transition:all .3s ease;background:#e2e8f0}
.thumb-item:hover{opacity:.9}
.thumb-item.active{opacity:1;border-color:var(--primary);box-shadow:0 5px 15px #0284c74d;}
.thumb-item img{width:100%;height:100%;object-fit:cover}
.lightbox:not(.boromfolders-gallery){position:fixed;inset:0;background:#0f172af2;z-index:9999;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;color:#fff;height:80px}
.lightbox-counter{font-size:1.2rem;font-weight:700;letter-spacing:2px;background:#ffffff1a;padding:.5rem 1.5rem;border-radius:50px}
.lightbox-close{background:#ffffff1a;border:1px solid #ffffff4d;color:#fff;font-size:2rem;cursor:pointer;width:48px;height:48px;border-radius:50%;display:flex;justify-content:center;align-items:center;transition:all .2s ease;z-index:100}
.lightbox-close:hover{background:#ffffff4d;transform:scale(1.1) rotate(90deg)}
.lightbox-content{flex:1;position:relative;display:flex;justify-content:center;align-items:center;padding:0 2rem;overflow:hidden}
.lightbox-img{max-width:100%;max-height:calc(100vh - 220px);object-fit:contain;border-radius:12px;box-shadow:0 20px 40px #00000080;user-select:none;transition:opacity .2s ease;position:relative;z-index:5}
.nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid #fff3;color:#fff;width:60px;height:60px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:1.5rem;cursor:pointer;backdrop-filter:blur(4px);transition:all .3s ease;z-index:10}
.nav-btn:hover{background:var(--summer-blue);border-color:var(--summer-blue);transform:translateY(-50%) scale(1.1)}
.nav-prev{left:3rem}
.nav-next{right:3rem}
.lightbox-thumbnails{height:120px;padding:1rem 2rem;display:flex;gap:12px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;align-items:center;border-top:1px solid #ffffff1a}
.lightbox-thumbnails::-webkit-scrollbar{display:none}
.lightbox-thumb{width:100px;height:70px;flex-shrink:0;border-radius:8px;overflow:hidden;cursor:pointer;opacity:.3;transition:all .3s ease;border:2px solid transparent}
.lightbox-thumb:hover{opacity:.8}
.lightbox-thumb.active{opacity:1;border-color:var(--accent);transform:scale(1.1);box-shadow:0 4px 10px #00000080}
.lightbox-thumb img{width:100%;height:100%;object-fit:cover}
@media (max-width: 992px) {
    .gallery-container{padding:2rem;border-radius:24px}
    .viewer-main{height:400px}
}
@media (max-width: 768px) {
    .gallery-container{padding:1.5rem}
    .viewer-main{height:280px;border-radius:16px}
    .category-info-overlay{top:1rem;left:1rem;right:1rem;max-width:none;padding:.8rem 1.2rem}
    .category-info-overlay h3{font-size:1.1rem}
    .category-info-overlay p{font-size:.85rem}
    .btn-expand-modal{bottom:1rem;right:1rem;padding:.6rem 1rem;font-size:.9rem}
    .thumb-item{flex:0 0 90px;height:60px}
    .lightbox-header{padding:1rem;height:60px}
    .lightbox-close{width:36px;height:36px;font-size:1.5rem}
    .lightbox-content{padding:0 1rem}
    .nav-btn{width:44px;height:44px;font-size:1.2rem}
    .nav-prev{left:1rem}
    .nav-next{right:1rem}
    .lightbox-img{max-height:calc(100vh - 180px)}
    .lightbox-thumbnails{padding:1rem;height:100px;gap:8px}
    .lightbox-thumb{width:80px;height:50px}
}
/*********************
비쥬얼::하단글래스모피즘
*********************/
.hero-section{position:relative;width:100%;min-height:90vh;display:flex;align-items:center;justify-content:center;overflow:hidden;background-color:#000}
.hero-section .dday{gap:10px!important}
.hero-section .dday>div{background:#f1f5f9;padding:20px 6px;border-radius:8px;border:1px solid #e1e1e1}
.hero-bg-slider{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-bg-pic{position:absolute;inset:0;width:100%;height:100%;opacity:0;transform:scale(1);transition:opacity 1.5s ease-in-out,transform 6s ease-out}
.hero-bg-pic.active{opacity:1;transform:scale(1.05);z-index:1}
.hero-bg-pic img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,#0f172acc 0%,#0f172a66 50%,#0f172a33 100%);z-index:1}
.hero-container{position:relative;z-index:2;width:100%;padding:0 2rem;display:flex;max-width:1600px;flex-direction:column;gap:4rem}
.hero-copy{flex:1;color:var(--text-light);animation:fadeUp 1s cubic-bezier(0.16,1,0.3,1) forwards;padding-bottom:200px}
.hero-copy .btn-group{width:360px}
@keyframes fadeUp {
    0%{opacity:0;transform:translateY(30px)}
    100%{opacity:1;transform:translateY(0)}
}
.hero-badge{display:inline-block;background:#ffffff26;backdrop-filter:blur(8px);border:1px solid #ffffff4d;color:#fde68a;padding:.6rem 1.2rem;border-radius:50px;font-size:.95rem;font-weight:700;margin-bottom:1.5rem;letter-spacing:.5px}
.hero-section .hero-title{font-size:6.3rem!important;font-weight:800;line-height:1.25;margin-bottom:1rem;text-shadow:0 4px 15px #0000004d;word-break:keep-all}
.hero-section .hero-title span{color:#60a5fa}
.hero-subtitle{font-size:2.2rem!important;font-weight:800;color:#fcd34d!important;margin-bottom:1.5rem!important;text-shadow:0 4px 10px #0000004d;text-align:left}
.hero-desc{font-size:1.2rem;line-height:1.6;color:#ffffffd9;max-width:500px;word-break:keep-all}
.hero-dashboard{ z-index: 2; background: #ffffff40; backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border: 1px solid #ffffff80; border-right: 1px solid #fff3; border-bottom: 1px solid #fff3; box-shadow: 0 25px 45px #0000001a; border-top-left-radius: 24px; border-top-right-radius: 24px; padding: 1.5rem 2rem; position: absolute; bottom: 0; width: 100%; max-width: 1600px;}
@keyframes fadeLeft {
    0%{opacity:0;transform:translateX(30px)}
    100%{opacity:1;transform:translateX(0)}
}
.dashboard-header{text-align:center;justify-content:start;display:flex;flex-direction:column;align-items:start}
.timer-label{font-size:.9rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px;margin-bottom:.8rem;display:block}
.timer-grid{display:flex;justify-content:center;gap:1rem}
.timer-box{display:flex;flex-direction:column;align-items:center;width:60px}
.timer-number{font-size:2.2rem;font-weight:800;color:var(--primary);line-height:1;background:#f1f5f9;width:100%;padding:.8rem 0;border-radius:12px;box-shadow:inset 0 2px 4px #0000000d;margin-bottom:.4rem}
.timer-text{font-size:.8rem;font-weight:600;color:var(--text-muted)}
.info-list{display:flex;justify-content:space-between;gap:36px;margin-bottom:2rem}
.info-row{display:flex;flex-direction:column;align-items:flex-start;gap:12px}
.info-row span,.info-row div:not(:first-child){color:#fff}
.info-row:last-child{margin-bottom:0}
.info-title{width:80px;font-weight:700;color:#fff;background-color:var(--primary);text-align:center;margin-right:8px;border-radius:24px;font-size:1rem;padding:4px 8px}
.info-content{flex:1;font-size:1.365rem;color:var(--text-main);line-height:1.5;font-weight:500}
.info-content span{display:block;margin-bottom:4px}
.btn-group{display:flex;gap:.8rem}
.btn-group .btn{width:100%;padding:1.2rem;border-radius:12px!important;font-size:1.1rem;font-weight:700;text-align:center;text-decoration:none;transition:all .3s ease;cursor:pointer;border:none}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 10px 20px #1e3a8a33}
.btn-primary:hover{background:#152c6b;color:#fff;transform:translateY(-2px);box-shadow:0 15px 25px #1e3a8a4d}
.btn-kakao{background:var(--kakao-yellow);color:var(--kakao-text)}
.btn-kakao:hover{background:#e6ce00;color:#222;transform:translateY(-2px)}
@media (max-width:992px) {
    .hero-section{height:500px;min-height:max-content}
    .hero-container{flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center;gap:3rem}
    .hero-overlay{background:linear-gradient(to bottom,#0f172acc 0%,#0f172a99 100%)}
    .hero-desc{margin:0 auto}
    .hero-dashboard{width:100%;max-width:500px;padding:2rem;transform:translateY(30px);animation:fadeUp 1s cubic-bezier(0.16,1,0.3,1) .3s forwards}
    .dashboard-header,.info-row:last-child{display:none}
    .info-list{margin-top:0;margin-bottom:0}
    .info-content span, .info-row div{font-size:14px!important}
}
@media (max-width:480px) {
    .hero-title{font-size:2.5rem}
    .hero-subtitle{font-size:1.8rem}
    .hero-desc{font-size:1.05rem}
    .timer-number{font-size:1.8rem;width:50px;padding:.6rem 0}
    .hero-dashboard{padding:10px 14px}
}
/*************
구형메인비쥬얼
*************/
.mainVis{height:calc(100dvh - 71px);min-height:calc(100dvh - 71px);position:relative;padding-top:3.5rem}
.mainVis_inner_txt{width:100%}
.vis-bg{position:absolute;top:0;left:0;z-index:0;width:100%;height:100%;overflow:hidden}
.vis-bg::after{content:'';display:block;width:100%;height:100%;background:#ffffff80;position:absolute;top:0;font-size:0}
.vis-bg img{width:100%;height:100%;object-fit:cover;object-position:100%}
.mainVis_inner_txt{z-index:1}
@media(min-width:993px) {
    .wp-child-theme-blocksy-royal .mainVis{padding-top:90px}
}
@media(min-width:993px) and (max-width:1400px) {
    #mainVis .mainVis_inner_txt h2{font-size:1.65em!important;margin-bottom:0!important}
    #mainVis .mainVis_inner_txt h1{font-size:78px!important}
    #mainVis .mainVis_inner_txt h3{font-size:24px!important;margin-top:0!important}
    #mainVis .card-hori .item img{width:40px!important;height:40px!important}
    #mainVis .ab-el.el-01{width:80px!important}
    #mainVis .ab-el.el-02{width:60px!important}
    #mainVis .card-hori .item h4,#mainVis .info .txt h5{font-size:20px!important}
    #mainVis .card-hori .item p{font-size:19px!important}
    #mainVis .info .txt p{font-size:19px!important}
    #mainVis .info .txt p small{font-size:16px!important}
    #mainVis .info .txt{gap:12px!important}
}
/**************
UI요소
**************/
.bg_gra{background:#8800BE;background:linear-gradient(to right,#8800BE 0%,#54008F 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.bg-shapes { position: absolute; inset: 0; overflow: hidden; z-index: 0; pointer-events: none; }
.w-box{background:#fff;border-radius:12px;display:flex;justify-content:center;flex-direction:column;align-items:center;border:1px solid #d0d0d0;padding:60px 40px}
.w-box.sm{padding:24px 36px}
.w-box.left{align-items:flex-start}
.box-1{padding:60px 40px;margin-top:30px;margin-bottom:40px}
.btn-apply{background:var(--summer-blue);color:#fff;border:none;padding:1rem;border-radius:8px;font-weight:700;font-size:1.1rem;width:100%;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 10px #0284c74d}
.btn-apply:hover{background:#0369a1;transform:translateY(-2px)}
.deco-shape { position: absolute; border-radius: 50%; filter: blur(60px); z-index: 0; opacity: 0.6; }
.shape-1 { width: 400px; height: 400px; background: var(--c1); top: -100px; left: -100px; }
.shape-2 { width: 300px; height: 300px; background: var(--secondary-color); bottom: -50px; right: -50px; }
.ottogi-animation { transform-origin: bottom center; animation: swing 4s ease-in-out infinite}
.circle { background: var(--c1); width: 100px; height: 100px; color: #fff; align-items: center; justify-content: center; display: flex; border-radius: 100%; font-size: 25px; font-weight: 600; position: absolute}
.circle{position:relative;top:auto!important;left:auto!important;right:auto!important;border-radius:0;width:100%;height:auto;padding:6px 14px;border-radius:8px;margin-bottom:20px}
.circle br{display:none}
.circle span span{margin-left:6px}
.phil{background: var(--c1); color: #fff; padding: 6px 20px; border-radius: 80px; display: inline-flex; margin-bottom: 20px;font-size:18px!important}
.shadow_1 { box-shadow: 0px 13.02px 29.59px 0px rgba(0, 0, 0, 0.1), 0px 53.25px 53.25px 0px rgba(0, 0, 0, 0.09), 0px 120.71px 72.19px 0px rgba(0, 0, 0, 0.05), 0px 214.2px 85.21px 0px rgba(0, 0, 0, 0.01), 0px 334.91px 93.49px 0px rgba(0, 0, 0, 0); }
.shadow_2 { box-shadow: 0px 6.51px 14.795px 0px rgba(0, 0, 0, 0.1), 0px 26.625px 26.625px 0px rgba(0, 0, 0, 0.09), 0px 60.355px 36.095px 0px rgba(0, 0, 0, 0.05), 0px 107.1px 42.605px 0px rgba(0, 0, 0, 0.01), 0px 167.455px 46.745px 0px rgba(0, 0, 0, 0); }
/**************
비쥬얼::하단티켓
**************/
.summer-hero{position:relative;width:100%;height:100vh;min-height:900px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.summer-hero .hero-bg-container{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.summer-hero .hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.5s ease-in-out}
.summer-hero .hero-media.active{opacity:1;z-index:1}
.summer-hero .mobile-fallback{display:none;position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2}
.summer-hero .hero-media img{ width: 100%; height: 100%; object-fit: cover; display: block;}

@media (max-width: 768px) {
    .summer-hero video.hero-media{display:none}
    .summer-hero .mobile-fallback{display:block}
}
.summer-hero .hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#0f172a66 0%,#0f172a33 40%,#0f172ab3 100%);z-index:0;pointer-events:none}
.summer-hero .hero-copy{ position: relative; z-index: 3; text-align: center; color: #fff; padding: 0 2rem 400px 2rem; transform: translateY(-10vh); animation: fadeUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;}
.summer-hero .hero-badge{display:inline-block;background:var(--summer-blue);color:#fff;padding:.5rem 1.2rem;border-radius:50px;font-size:1rem;font-weight:800;letter-spacing:1px;margin-bottom:1.5rem;text-transform:uppercase;box-shadow:0 4px 15px #0284c766}
.summer-hero .hero-title{font-size:6.3rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem;word-break:keep-all;text-shadow:0 10px 30px #00000080}
.summer-hero .hero-title span{color:#7dd3fc}
.summer-hero .hero-desc{font-size:1.3rem!important;line-height:1.6!important;color:#ffffffe6!important;max-width:800px;margin:0 auto;word-break:keep-all;text-shadow:0 4px 10px #00000080;text-align:left}
.summer-hero .ticket-wrapper{position:absolute;bottom:0px;left:50%;transform:translateX(-50%);width:95%;max-width:1400px;z-index:4;filter:drop-shadow(0 30px 50px #0006);animation:slideUpTicket 1s cubic-bezier(0.16,1,0.3,1) .5s forwards;opacity:0}
@media(min-width:769px) and (max-width:1024px){
    .summer-hero .hero-title{font-size:3.5rem}
}
@media(max-width:768px){
    .summer-hero .hero-title{font-size:2.2rem}
}
/*************
티켓
*************/
.ticket{display:flex;background:var(--ticket-bg);backdrop-filter:blur(16px);border-top-left-radius:20px;border-top-right-radius:20px;overflow:hidden;position:relative}
.ticket-main { flex: 3; padding: 0.5rem 3rem; border-right: 3px dashed #cbd5e1; position: relative; display: flex; flex-direction: column; justify-content: center;}
.ticket-main::before,.ticket-main::after{content:'';position:absolute;right:-15px;width:30px;height:30px;background:#1e293b;border-radius:50%;z-index:10}
.ticket-main::before{top:-15px}
.ticket-main::after{bottom:-15px}
.ticket-content-row{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.ticket-branding{display:flex;flex-direction:column;gap:1rem;min-width:250px}
.ticket-logo{font-size:1.1rem;font-weight:800;color:var(--summer-blue);letter-spacing:1px;display:flex;align-items:center;gap:.5rem}
.ticket-class{background:var(--summer-coral);color:#fff;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;margin-left:auto}
.ticket-info-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;flex:1;padding-left:2rem;border-left:1px solid #e2e8f0}
.ticket-stub{flex:1;min-width:300px;padding:2rem;background:#f8fafcf2;display:flex;flex-direction:column;justify-content:space-between;align-items:center;position:relative}
.ticket-timer{width:100%;text-align:center;background:var(--summer-dark);color:#fff;padding:.8rem;border-radius:12px;margin-bottom:1rem}
.airport{font-size:1.6rem;font-weight:800;color:var(--summer-blue)}
.airport-desc{font-size:.7rem;color:var(--text-muted);display:block;text-align:center}
.route-icon{color:var(--summer-coral);font-size:1.2rem}
.info-box{display:flex;flex-direction:column}
.info-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;font-weight:700;margin-bottom:.3rem}
.info-value{font-size:1.1rem;font-weight:800;color:var(--text-main);white-space:nowrap}
.barcode-horizontal { width: 20%; height: 15px; background: repeating-linear-gradient(to right, #1e293b, #1e293b 2px, transparent 2px, transparent 4px, #1e293b 4px, #1e293b 8px, transparent 8px, transparent 10px, #1e293b 10px, #1e293b 11px); margin-bottom: 1rem; opacity: .7; position: absolute; top: 30px; right: 78px; opacity: 0.3}
.ticket-info-grid .info-box:last-child .info-value { font-size: 2rem; }
.ticket-info-grid .info-box:last-child .info-label { text-align: right;}
.timer-title{display:block;font-size:.7rem;font-weight:700;color:var(--summer-coral);text-transform:uppercase;margin-bottom:.2rem}
.timer-numbers{font-size:1.3rem;font-weight:800;letter-spacing:1px}
.flight-route{display:flex;align-items:center;gap:1rem;background:#f8fafc;padding:.8rem 1.2rem;border-radius:12px}
@media (max-width: 1200px) {
    .ticket-content-row{flex-direction:column;align-items:stretch;gap:1.5rem}
    .ticket-info-grid{border-left:none;padding-left:0;grid-template-columns:repeat(2,1fr);gap:1rem}
    .ticket-branding{flex-direction:row;justify-content:space-between;align-items:center}
    .flight-route{margin-bottom:0}
}
@media (max-width: 992px) {
    .hero-title{font-size:3.5rem}
    .hero-copy{transform:translateY(-15vh)}
    .ticket-wrapper{width:90%;max-width:600px;bottom:2rem}
    .ticket{flex-direction:column}
    .ticket-main{border-right:none;border-bottom:3px dashed #cbd5e1;padding:1.5rem}
    .ticket-main::before,.ticket-main::after{right:auto;bottom:-15px;background:transparent}
    .ticket-main::before{left:-15px}
    .ticket-main::after{right:-15px}
    .ticket-stub{padding:1.5rem;min-width:auto}
    .barcode-horizontal{display:none}
    .ticket-branding{flex-direction:column;align-items:stretch}
    .flight-route{justify-content:center}
}
@media (max-width: 480px) {
    .hero-title{font-size:2.2rem}
    .hero-desc{font-size:1rem}
    .airport{font-size:1.4rem}
    .info-value{font-size:1rem}
}
/**************
블롭
**************/
.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);z-index:0;opacity:.5;pointer-events:none}
.blob-1{width:500px;height:500px;background:#3b82f633;top:-100px;left:-100px}
.blob-2{width:400px;height:400px;background:#d9770626;bottom:100px;right:-100px}
@media(max-width:992px){
    .bg-blob{display:none!important}
}
/**************
마퀴
**************/
.marquee-container { width: 100vw; margin-left: calc(-50vw + 50%); overflow: hidden; display: flex; flex-wrap:nowrap}
.marquee-content { display: flex; flex-shrink:0;gap:30px;padding-right: 30px;animation: scrolling 20s linear infinite}
.marquee-content img { width: 400px; height: auto; object-fit: cover; border-radius: 20px; }
@keyframes scrolling {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}
@media(max-width:992px){
    .tri-images,.marquee-content img{height:240px!important}
}
/****************
스티키 스텝카드
*****************/
.royal-section { position: relative; width: 100%;margin: 0 auto; background: linear-gradient(-45deg, #eef2ff, #f3e8ff, #fffbeb, #e0e7ff); background-size: 400% 400%; animation: gradientBG 15s ease infinite; box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.05); }
.royal-section .container-section { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: start; }
.sticky-wrapper { position: sticky; top: 10vh;display: flex; flex-direction: column; gap: 2rem; }
.title-area h1 { font-size: 3.5rem; font-weight: 800; line-height: 1.2; letter-spacing: -0.02em; margin-bottom: 1rem; background: linear-gradient(135deg, #3730a3, #7c3aed); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.title-area h2 { font-size: 1.5rem; font-weight: 600; color: var(--text-muted); border-left: 4px solid var(--c1); padding-left: 1rem; }
.image-box { position: relative; width: 100%; aspect-ratio: 4/5; border-radius: 24px; overflow: hidden; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1);animation: floating 6s ease-in-out infinite}
.image-box img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0;  transition: opacity 0.8s ease-in-out, transform 0.8s ease; }
.image-box img.active { opacity:1; z-index: 2; }
.image-box:hover img.active { transform: scale(1.05)}
.academy-name { font-size: 0.9rem; font-weight: 600; color: #94a3b8; letter-spacing: 0.1em; text-transform: uppercase; margin-top: 1rem; }
.scroll-wrapper { padding-top: 2rem; padding-bottom: 20vh;position: relative}
.scroll-wrapper::before{content: ''; position: absolute; top: 4rem; bottom: 20vh; left: 24px; width: 2px; background: rgba(99, 102, 241, 0.2); z-index: 0}
@media(max-width:992px){
    .royal-section .container-section{grid-template-columns:1fr}
}
/********
스텝카드
*********/
.step-card {position: sticky; z-index: 1; background: var(--card-bg); backdrop-filter: blur(12px); border-top: 1px solid rgba(255, 255, 255, 1); border-left: 1px solid rgba(255, 255, 255, 0.6); border-right: 1px solid rgba(255, 255, 255, 0.6); border-bottom: 1px solid rgba(255, 255, 255, 0.3); border-radius: 24px; padding: 2.5rem; margin-bottom: 50vh;box-shadow: 0 -15px 25px rgba(0, 0, 0, 0.04), 0 15px 35px rgba(0, 0, 0, 0.04);opacity: 0; transition: opacity 0.8s ease}
.step-card:nth-child(1) { top: 10vh; z-index: 10; }
.step-card:nth-child(2) { top: calc(10vh + 25px); z-index: 11; }
.step-card:nth-child(3) { top: calc(10vh + 50px); z-index: 12; }
.step-card:nth-child(4) { top: calc(10vh + 75px); z-index: 13; }
.step-card:nth-child(5) { top: calc(10vh + 100px); z-index: 14; }
.step-card::before { content: ''; position: absolute; left: -32px; top: 3.5rem; width: 18px; height: 18px; border-radius: 50%; background: var(--bg-color); border: 4px solid var(--c1); transition: all 0.4s ease; box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.1)}
.step-card.visible { opacity:1}
.step-card.visible::before { background: var(--c1); transform: scale(1.2); box-shadow: 0 0 15px rgba(99, 102, 241, 0.5); }
.step-card:hover{box-shadow: 0 -15px 30px rgba(99, 102, 241, 0.1), 0 20px 40px rgba(0, 0, 0, 0.08); border-top-color: rgba(99, 102, 241, 0.4); }
.step-badge { display: inline-block; background: var(--c1); color: white; padding: 0.4rem 1rem; border-radius: 50px; font-size: 0.9rem; font-weight: 700; margin-bottom: 1rem; box-shadow: 0 4px 10px rgba(99, 102, 241, 0.3); }
.step-card[data-step="2"] .step-badge { background: #10b981; box-shadow: 0 4px 10px rgba(16, 185, 129, 0.3); }
.step-card[data-step="3"] .step-badge { background: #f59e0b; box-shadow: 0 4px 10px rgba(245, 158, 11, 0.3); }
.step-card[data-step="4"] .step-badge { background: #ec4899; box-shadow: 0 4px 10px rgba(236, 72, 153, 0.3); }
.step-card[data-step="5"] .step-badge { background: #8b5cf6; box-shadow: 0 4px 10px rgba(139, 92, 246, 0.3); }
.step-title { font-size: 1.5rem; font-weight: 700; margin-bottom: 1rem; color: var(--text-main); }
.step-desc { font-size: 1.05rem; line-height: 1.6; color: var(--text-muted); word-break: keep-all; }
.highlight-text { display: inline-block; background: linear-gradient(120deg, rgba(245, 158, 11, 0.3) 0%, rgba(245, 158, 11, 0.3) 100%); background-repeat: no-repeat; background-size: 100% 40%; background-position: 0 88%; font-weight: 600; color: var(--text-main); }
@media (max-width:992px) {
    .sticky-wrapper { position: relative; top: 0; margin-bottom: 3rem; text-align: center; }
    .title-area h2 { border-left: none; border-top: 4px solid var(--c1); padding-left: 0; padding-top: 1rem; display: inline-block; }
    .image-box { max-width: 500px; margin: 0 auto; aspect-ratio: 16/9; }
    .scroll-wrapper { padding-bottom: 2rem; }
    .scroll-wrapper::before { left: 20px; }
    .step-card { position: relative !important; top: 0 !important; opacity: 1 !important; margin-left: 40px; padding: 1.5rem; margin-bottom: 2rem !important; }
    .step-card::before { left: -29px; }
}
@media (max-width:480px) {
    .title-area h1 { font-size: 2.5rem; }
    .step-title { font-size: 1.3rem; }
}
/************
뱃지
************/
.badge-container { padding: 10px; display: inline-block; position: absolute; z-index: 1; top: -10px; right: 11px}
.badge-outer { display: inline-block; position: relative; width: 106px; height: 86px; background: linear-gradient(135deg, #FFD700, #D4A017, #996515); clip-path: polygon(0% 0%, 100% 0%, 100% 70%, 50% 100%, 0% 70%)}
.badge-inner { text-align: center; position: absolute; top: 3px; left: 3px; right: 3px; bottom: 3px; background-color: #222; clip-path: polygon(0% 0%, 100% 0%, 100% 70%, 50% 100%, 0% 70%); display: flex; align-items: center; justify-content: center}
.badge-text { font-size: 24px; font-weight: 700; background: linear-gradient(135deg, #FFD700, #D4A017); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; text-fill-color: transparent; padding-bottom: 15px}
@media (max-width:992px) {
    .badge-outer { width: 80px; height: 52px }
    .badge-container { top: -10px; right: 0 }
    .badge-text { font-size: 16px; line-height: 1; padding-bottom: 0 }
    .badge-inner { justify-content: center; align-items: center }
}
/*********
쿠폰
*********/
.coupon{width:80%;margin-bottom:12px}
.coupon { background: linear-gradient(-89.69deg, rgba(136, 32, 252, 1) 0%, rgba(52, 50, 247, 1) 51.499998569488525%, rgba(52, 50, 247, 1) 100%); border-radius: 8.49px; padding: 24px 12px; display: flex; flex-direction: column; gap: 5px; align-items: center; justify-content: center; width: 50%; position: relative; margin: 0 auto 20px; }
.coupon::after { content: ''; width: 34px; height: 34px; background: #fff; position: absolute; border-radius: 100%; right: -17px}
main .coupon h3{font-size:50px!important}
.coupon h6,.coupon h5,.coupon h3,.coupon p,.coupon-type-2 h6,.coupon-type-2 h5,.coupon-type-2 h3,.coupon-type-2 p { color: #fff}
.coupon h3,.coupon-type-2 h3 { font-size: 63px; font-weight: 900}
.coupon h3 small,.coupon-type-2 h3 small { font-weight: 700; font-size: 0.9rem}
.coupon h5,.coupon-type-2 h5 { margin-bottom: 0 !important}
.sale { text-decoration: line-through; margin-right: 6px}
/*쿠폰타입2*/
.coupon-type-2 { -webkit-mask-image: radial-gradient(circle at 50px 10px, transparent 10px, red 10.5px), radial-gradient(closest-side circle at 50%, red 99%, transparent 100%); -webkit-mask-size: 100%, 5px 13px; -webkit-mask-repeat: repeat, repeat-y; -webkit-mask-position: 0 -10px, 47.5px; -webkit-mask-composite: source-out; mask-composite: subtract; width: 90%; height: 235px; margin: 2rem auto; border-radius: .5rem; background: linear-gradient(var(--c1), var(--c2)); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.coupon-type-2 h3 span { font-size: 4.65rem; }
@media(max-width:992px) {
    .coupon-type-2 { width: 100% }
}
/***********
티켓
***********/
.ticket-system { max-width: 385px; margin: 0 auto}
.ticket-system .receipts-wrapper { overflow: hidden; padding-bottom: 10px}
.ticket-system .receipts { width: 100%; display: flex; align-items: center; flex-direction: column}
.ticket-system .receipts .receipt { padding: 25px 30px; text-align: left; min-height: 200px; width: 100%; background-color: #fff; border-radius: 10px 10px 20px 20px; box-shadow: 1px 3px 8px 3px #0003; position: relative; z-index: 1; width: calc(100% - 24px); margin: -3px auto 0; }
.ticket-system .receipt { position: relative; width: 350px; height: 335px; padding-top: 40px; margin: 20px auto; border-radius: 20px 20px 0 0; text-align: center; background: rgb(41, 40, 38); background: -webkit-linear-gradient(top, rgba(41, 40, 38, 1) 0%, rgba(207, 207, 207, 1) 0%, rgba(218, 218, 218, 1) 1%, rgba(240, 240, 240, 1) 2%, rgba(245, 245, 245, 1) 2%, rgba(246, 246, 246, 1) 2%, rgba(243, 243, 243, 1) 3%, rgba(227, 227, 227, 1) 5%, rgba(222, 222, 222, 1) 5%, rgba(225, 225, 225, 1) 8%, rgba(238, 238, 238, 1) 12%, rgba(253, 253, 253, 1) 23%, rgba(253, 253, 253, 1) 27%, rgba(249, 249, 249, 1) 31%, rgba(227, 227, 227, 1) 43%, rgba(226, 226, 226, 1) 49%, rgba(231, 231, 231, 1) 56%, rgba(253, 253, 253, 1) 74%, rgba(255, 255, 255, 1) 82%, rgba(249, 249, 249, 1) 87%, rgba(230, 230, 230, 1) 97%, rgba(227, 227, 227, 1) 100%); background: -moz-linear-gradient(top, rgba(41, 40, 38, 1) 0%, rgba(207, 207, 207, 1) 0%, rgba(218, 218, 218, 1) 1%, rgba(240, 240, 240, 1) 2%, rgba(245, 245, 245, 1) 2%, rgba(246, 246, 246, 1) 2%, rgba(243, 243, 243, 1) 3%, rgba(227, 227, 227, 1) 5%, rgba(222, 222, 222, 1) 5%, rgba(225, 225, 225, 1) 8%, rgba(238, 238, 238, 1) 12%, rgba(253, 253, 253, 1) 23%, rgba(253, 253, 253, 1) 27%, rgba(249, 249, 249, 1) 31%, rgba(227, 227, 227, 1) 43%, rgba(226, 226, 226, 1) 49%, rgba(231, 231, 231, 1) 56%, rgba(253, 253, 253, 1) 74%, rgba(255, 255, 255, 1) 82%, rgba(249, 249, 249, 1) 87%, rgba(230, 230, 230, 1) 97%, rgba(227, 227, 227, 1) 100%); background: -o-linear-gradient(top, rgba(41, 40, 38, 1) 0%, rgba(207, 207, 207, 1) 0%, rgba(218, 218, 218, 1) 1%, rgba(240, 240, 240, 1) 2%, rgba(245, 245, 245, 1) 2%, rgba(246, 246, 246, 1) 2%, rgba(243, 243, 243, 1) 3%, rgba(227, 227, 227, 1) 5%, rgba(222, 222, 222, 1) 5%, rgba(225, 225, 225, 1) 8%, rgba(238, 238, 238, 1) 12%, rgba(253, 253, 253, 1) 23%, rgba(253, 253, 253, 1) 27%, rgba(249, 249, 249, 1) 31%, rgba(227, 227, 227, 1) 43%, rgba(226, 226, 226, 1) 49%, rgba(231, 231, 231, 1) 56%, rgba(253, 253, 253, 1) 74%, rgba(255, 255, 255, 1) 82%, rgba(249, 249, 249, 1) 87%, rgba(230, 230, 230, 1) 97%, rgba(227, 227, 227, 1) 100%); box-shadow: 0 5px 10px 0px #555; }
.ticket-system .receipt:after,.ticket-system .receipts:before { display: block; content: ""; position: absolute}
.ticket-system .receipt:after { width: 100%; height: 10px; top: 100%; left: 0; margin-top: -10px; -webkit-filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.4)); background: -webkit-radial-gradient(transparent 0, transparent 6px, #e1e1e0 4px, #e1e1e0); background-size: 20px 30px; background-position: 5px 0; background-repeat: repeat-x; }
.ticket-system .receipts .receipt h4 { border-bottom: 1px dashed #b4b4b4; font-size: 23px; margin: 0 11px 19px 0}
.ticket-system .receipts:before { width: 100%; height: 10px; top: 0; left: 0px; position: relative; z-index: -1; border-radius: 10px; background: #000; background: -webkit-linear-gradient(top, rgba(0, 0, 0, 1) 0%, rgba(29, 25, 26, 1) 11%, rgba(25, 23, 24, 1) 22%, rgba(44, 42, 43, 1) 33%, rgba(46, 42, 43, 1) 47%, rgba(0, 0, 0, 1) 48%, rgba(0, 0, 0, 1) 53%, rgba(0, 0, 0, 1) 58%, rgba(74, 74, 74, 1) 58%, rgba(78, 78, 78, 1) 78%, rgba(85, 85, 85, 1) 89%, rgba(0, 0, 0, 1) 100%); background: -moz-linear-gradient(top, rgba(0, 0, 0, 1) 0%, rgba(29, 25, 26, 1) 11%, rgba(25, 23, 24, 1) 22%, rgba(44, 42, 43, 1) 33%, rgba(46, 42, 43, 1) 47%, rgba(0, 0, 0, 1) 48%, rgba(0, 0, 0, 1) 53%, rgba(0, 0, 0, 1) 58%, rgba(74, 74, 74, 1) 58%, rgba(78, 78, 78, 1) 78%, rgba(85, 85, 85, 1) 89%, rgba(0, 0, 0, 1) 100%); background: -o-linear-gradient(top, rgba(0, 0, 0, 1) 0%, rgba(29, 25, 26, 1) 11%, rgba(25, 23, 24, 1) 22%, rgba(44, 42, 43, 1) 33%, rgba(46, 42, 43, 1) 47%, rgba(0, 0, 0, 1) 48%, rgba(0, 0, 0, 1) 53%, rgba(0, 0, 0, 1) 58%, rgba(74, 74, 74, 1) 58%, rgba(78, 78, 78, 1) 78%, rgba(85, 85, 85, 1) 89%, rgba(0, 0, 0, 1) 100%); }
@media(max-width:992px) {
    .ticket-system .receipts .receipt { height: auto; padding: 30px 14px }
    .ticket-system .receipts ul li { font-size: 17px !important }
}
/***************
실적
***************/
.main-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}
.stat-unit{font-size:1.5rem;font-weight:700;color:var(--text-main)}
.details-container{background:var(--surface);border-radius:32px;padding:4rem;box-shadow:0 20px 40px #0000000a;border:1px solid #00000005}
.details-title{font-size:1.4rem;font-weight:800;color:var(--text-main);margin-bottom:2.5rem;padding-bottom:1rem;border-bottom:2px solid var(--border-color)}
.progress-list{display:flex;flex-direction:column;gap:1.8rem}
.progress-item{display:flex;flex-direction:column;gap:.8rem}
.progress-header{display:flex;justify-content:space-between;align-items:flex-end}
.progress-name{font-size:1.1rem;font-weight:700;color:var(--text-main)}
.progress-count{font-size:1.2rem;font-weight:800;color:var(--summer-blue)}
.progress-count span{font-size:.9rem;color:var(--text-muted);font-weight:600}
.progress-track{width:100%;height:12px;background:#f1f5f9;border-radius:10px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--summer-blue),#38bdf8);border-radius:10px;width:0;transition:width 1.5s cubic-bezier(0.16,1,0.3,1)}
.progress-item:nth-child(1) .progress-fill{background:linear-gradient(90deg,#6366f1,#818cf8)}
.progress-item:nth-child(2) .progress-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}
.progress-item:nth-child(3) .progress-fill{background:linear-gradient(90deg,#10b981,#34d399)}
.section-footer{margin-top:2rem;text-align:center;font-size:.9rem;color:#94a3b8;font-weight:500}
@media (max-width: 768px) {
    .main-stats-grid{grid-template-columns:1fr;gap:1.5rem}
    .stat-card{padding:2.5rem 1.5rem;border-radius:24px}
    .stat-number{font-size:3.5rem}
    .details-container{padding:2.5rem 1.5rem;border-radius:24px}
    .progress-name{font-size:1rem}
    .progress-count{font-size:1.1rem}
}
/***************
아코디언
***************/
.borom-accordion{position:relative;background-color:#fff;color:#222;cursor:pointer;padding:26px 32px;border-radius:12px;width:100%;border:none;text-align:left;outline:none;font-size:24px;transition:.4s;margin-bottom:2px;font-weight:600}
.borom-accordion.active,.borom-accordion:hover{background-color:#ddd}
.borom-accordion:after{content:'\02795';font-size:13px;color:#777;margin-left:5px;position:absolute;right:30px;top:50%;transform:translateY(-50%)}
.borom-accordion.active:after{content:"\2796"}
.panel{padding:0 36px 0 64px;background-color:#fff;max-height:0;overflow:hidden;transition:max-height .2s ease-out;margin-bottom:10px}
.borom-accordion.active+.panel{padding-top:48px;padding-bottom:64px}
.panel ul li,.panel *{font-size:20px!important;color:#666}
@media (max-width:992px) {
    .borom-accordion{padding:10px 34px 10px 20px;font-size:19px;border-radius:0}
    .borom-accordion.active+.panel{padding-left:20px;padding-top:30px}
    .panel ul li,.panel *{font-size:17px!important}
}
/********
교재
********/
.main-tabs{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}
.main-tab-btn{background:var(--surface);border:2px solid var(--border-color);color:var(--text-muted);padding:.8rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:800;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px #00000005}
.main-tab-btn:hover{border-color:var(--summer-blue);color:var(--primary)}
.main-tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 10px 20px #0284c733;transform:translateY(-2px)}
.main-pane{display:none;animation:fadeIn .5s ease}
.main-pane.active{display:block}
.roadmap-hero{position:relative;width:100%;height:400px;border-radius:32px;overflow:hidden;margin-bottom:3rem;box-shadow:0 25px 50px -12px #0000001a}
.roadmap-hero img{width:100%;height:100%;object-fit:cover}
.roadmap-overlay{position:absolute;inset:0;background:linear-gradient(to top,#0f172acc 0%,#0f172a00 50%);display:flex;align-items:flex-end;padding:3rem}
.roadmap-overlay h3{color:#fff;font-size:2.2rem;font-weight:800;text-shadow:0 4px 10px #0000004d}
.sub-tabs-wrapper{background:var(--surface);padding:1rem;border-radius:20px;box-shadow:0 10px 30px #00000008;margin-bottom:2rem;border:1px solid var(--border-color)}
.sub-tabs{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.sub-tabs::-webkit-scrollbar{display:none}
.sub-tab-btn{white-space:nowrap;background:transparent;border:none;color:var(--text-muted);padding:.8rem 1.5rem;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .2s ease}
.sub-tab-btn:hover{background:#f1f5f9;color:var(--text-main)}
.sub-tab-btn.active{background:#f0f9ff;color:var(--primary)}
.sub-pane{display:none;animation:fadeIn .4s ease}
.sub-pane.active{display:block}
.course-track-wrapper{position:relative;width:100%}
.course-track-wrapper::after{content:'';position:absolute;right:0;top:0;bottom:0;width:80px;background:linear-gradient(to left,var(--bg-main) 0%,transparent 100%);pointer-events:none;z-index:2}
.course-track {
    display: flex;
    overflow-x: auto;
    padding-bottom: 2rem;
    padding-right: 80px;
    scroll-snap-type: x mandatory;
    scrollbar-width: thin;
    scrollbar-color: #cbd5e1 transparent;
    cursor: grab;
    user-select: none; 
    -webkit-user-select: none;
}

.course-track::-webkit-scrollbar{height:8px}
.course-track::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:10px}
.course-card{flex:0 0 320px;background:var(--surface);border-radius:24px;padding:2rem;border:1px solid var(--border-color);box-shadow:0 10px 25px #00000008;scroll-snap-align:start;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}
.course-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0284c714;border-color:#0284c733}
.course-img-stack{width:100%;height:180px;background:#f8fafc;border-radius:16px;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;padding:1rem}
.course-img-stack img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 15px #0000001a);transition:transform .4s ease}
.course-card:hover .course-img-stack img{transform:scale(1.05) translateY(-5px)}
.course-level-badge{display:inline-block;align-self:flex-start;background:#f0f9ff;color:var(--summer-blue);padding:.3rem .8rem;border-radius:8px;font-size:.85rem;font-weight:800;margin-bottom:.8rem}
.course-title{font-size:1.1rem!important;font-weight:700;color:var(--text-main);margin-bottom:1.0rem;line-height:1.3}
.book-list{list-style:none;margin-top:auto;padding-top:1.2rem;border-top:1px dashed var(--border-color)}
#curriculum-section .book-list li{position:relative;padding-left:1.2rem;font-size:.95rem;color:var(--text-muted);margin-bottom:.5rem;line-height:1.4;font-weight:600}
@media (max-width: 1024px) {
    .roadmap-hero{height:350px}
    .swipe-hint{display:block}
}
@media (max-width: 768px) {
    .roadmap-hero{height:200px;border-radius:20px}
    .roadmap-overlay{padding:1.5rem}
    .roadmap-overlay h3{font-size:1.5rem}
    .main-tabs{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding-bottom:1rem;-webkit-overflow-scrolling:touch}
    .main-tab-btn{white-space:nowrap;font-size:1rem;padding:.6rem 1.5rem}
    .course-card{flex:0 0 280px;padding:1.5rem}
    .course-img-stack{height:150px}
    .course-card{padding:20px 30px}
}
/*******
차트
*******/
.chart-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;text-align:center}
.chart-item{display:flex;flex-direction:column;align-items:center}
.circular-chart{position:relative;width:160px;height:160px;border-radius:50%;background:conic-gradient(var(--summer-blue) calc(var(--progress) * 1%),#e2e8f0 0deg);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;transition:--progress 2s ease-out}
.chart-svg{transform:rotate(-90deg);width:160px;height:160px}
.chart-circle-bg{fill:none;stroke:#e2e8f0;stroke-width:8}
.chart-circle{fill:none;stroke:var(--summer-blue);stroke-width:8;stroke-dasharray:440;stroke-dashoffset:440;stroke-linecap:round;transition:stroke-dashoffset 2s cubic-bezier(0.16,1,0.3,1)}
.chart-inner{position:absolute;width:130px;height:130px;background:var(--surface);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:inset 0 2px 5px #0000000d}
.chart-percentage{font-size:2.2rem;font-weight:900;color:var(--text-main);line-height:1}
.chart-percentage span{font-size:1.2rem;color:var(--text-muted)}
.chart-title{font-size:1.2rem;font-weight:800;color:var(--text-main);margin-bottom:.5rem}
.chart-desc{font-size:.95rem;color:var(--text-muted);word-break:keep-all;line-height:1.5}
.photo-grid-container{width:100%}
.real-photo-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:200px 200px;gap:1rem;border-radius:24px;overflow:hidden}
.photo-item{position:relative;overflow:hidden;border-radius:12px}
.photo-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.photo-item:hover img{transform:scale(1.05)}
.photo-large{grid-column:span 2;grid-row:span 2}
.photo-wide{grid-column:span 2;grid-row:span 1}
.photo-tall{grid-column:span 1;grid-row:span 2}
.photo-caption{position:absolute;bottom:0;left:0;right:0;padding:1.5rem 1rem 1rem;background:linear-gradient(transparent,#000000b3);color:#fff;font-weight:700;font-size:.95rem;opacity:1;transition:all .3s ease}
.photo-item:hover .photo-caption{transform:translateY(0);opacity:1}
.handwritten-container{width:100%;position:relative;margin-top:20px}
.handwritten-container{padding:0 40px!important}
.reviewSwiper{overflow:hidden}
.review-track{display:flex;gap:2rem;overflow-x:auto;padding:1rem 0 2rem;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.review-track::-webkit-scrollbar{display:none}
.review-card{background:var(--paper-bg);border-radius:20px;padding:1.5rem;box-shadow:0 10px 20px #0000000a;border:1px solid #0000000d;scroll-snap-align:start;position:relative;transition:transform .3s ease}
.review-card:hover{transform:translateY(-8px);box-shadow:0 15px 30px #00000014}
.review-card::before{content:'';position:absolute;top:-10px;left:50%;transform:translateX(-50%) rotate(-2deg);width:80px;height:25px;background:#fff9;border:1px solid #0000000d;box-shadow:0 2px 4px #0000000d;z-index:2}
.scan-img-box{width:100%;height:300px;background:#f1f5f9;border-radius:12px;overflow:hidden;margin-bottom:1.5rem;position:relative}
.scan-img-box img{width:100%;height:100%;object-fit:cover}
.zoom-icon{position:absolute;bottom:10px;right:10px;background:#00000080;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.review-quote{font-size:1.1rem;font-weight:800;color:var(--text-main);margin-bottom:.8rem;line-height:1.4;word-break:keep-all}
.review-author{font-size:.95rem;font-weight:600;color:var(--text-muted);text-align:right;border-top:1px dashed var(--border-color);padding-top:.8rem}
@media (max-width: 992px) {
    .chart-grid{grid-template-columns:1fr;gap:2rem}
    .chart-item{flex-direction:row;text-align:left;gap:2rem;background:#f8fafc;padding:1.5rem;border-radius:20px}
    .chart-container{padding:2rem}
    .circular-chart{margin-bottom:0;width:120px;height:120px;flex-shrink:0}
    .chart-svg{width:120px;height:120px}
    .chart-inner{width:96px;height:96px}
    .chart-percentage{font-size:1.6rem}
    .real-photo-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:auto}
    .photo-large{grid-column:span 2;grid-row:span 1;height:250px}
    .photo-wide{grid-column:span 2;height:200px}
    .photo-tall{grid-column:span 1;grid-row:span 1;height:200px}
    .photo-item:nth-child(4),.photo-item:nth-child(5){height:200px}
    .swipe-hint{display:block}
}
@media (max-width: 768px) {
    .proof-section{gap:4rem}
    .chart-item{flex-direction:column;text-align:center;gap:1rem}
    .review-card{width:100%}
    .scan-img-box{height:250px}
}
/******
*폼
******/
#contactUS .contact-wrap{background:#fff;padding:40px 60px;border-radius:24px;box-shadow:0 25px 50px -12px #0000000d}
/*
#contactUS .fluentform .ff-el-input--label{color:#fff}
#contactUS .contact-wrap .fluentform .ff-el-input--label{color:#222}
#contactUS input[type="text"],#contactUS input[type="email"],#contactUS textarea{width:100%;padding:1.2rem;background:var(--input-bg);border:1.5px solid var(--border-color);border-radius:16px;font-size:1.05rem;color:var(--text-main);transition:all .3s ease;outline:none}
#contactUS .contact-wrap input[type="text"],#contactUS .contact-wrap input[type="email"],#contactUS .contact-wrap textarea{color:#222}
#contactUS .contact-wrap .ff-default .ff-el-form-check label.ff-el-form-check-label{color:#222;width:100%}
#contactUS .contact-wrap .fluentform .ff-el-group.ff_list_buttons .ff-el-form-check label:focus-within span{background-color:#fff;background-color:#fff}
#contactUS .contact-wrap .fluentform .ff-el-group.ff_list_buttons .ff-el-form-check:not(.ff_item_selected) label:focus-within span{background-color:#fff!important;color:#606266!important;border:1px solid #dcdfe6!important}
#contactUS .fluentform .ff-el-group.ff_list_buttons .ff-el-form-check:not(.ff_item_selected) label:focus-within span{background-color:#fff!important;color:#606266!important;border:1px solid #dcdfe6!important}
#contactUS .contact-wrap .fluentform .ff-el-group.ff_list_buttons .ff-el-form-check:not(.ff_item_selected) label>span{background-color:#fff;color:#606266!important;border:1px solid #dcdfe6!important;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1.2rem;background:var(--surface);border:1.5px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s ease;text-align:center;height:100%}
#contactUS .contact-wrap .ff_list_buttons .ff-el-input--content{gap:1rem!important;display:flex}
#contactUS .list-prgr .ff_item_selected label>span{background-color:#fff!important;border-color:var(--primary);color:var(--primary)!important;border-radius:16px;border:1.5px solid var(--primary);box-shadow:0 4px 15px #1e3a8a1a}
.pop-refund{background:#fc0;color:#1f1f1f;border-radius:3px;padding:2px 4px;margin-left:7px;font-weight:500;font-size:16px}
.check-msg .ff-el-form-check.ff-el-form-check- label{display:flex;align-items:center;gap:.8rem;background:#f8fafc;padding:1.2rem;border-radius:12px;border:1px solid var(--border-color)}
.check-msg .ff-el-form-check.ff-el-form-check-,.check-msg .ff-el-form-check.ff-el-form-check- label{width:100%!important;display:flex!important;max-width:100%}


#contactUS .fluentform .ff_list_buttons .ff-el-input--content {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    width: 100% !important;
}
#contactUS .fluentform .ff_list_buttons .ff-el-input--content > div {
    flex: 1 !important;
}
#contactUS .fluentform .ff_list_buttons label span {
    width: 100% !important;
    min-height: 60px !important;
    padding: 10px 15px !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    color: var(--text-main) !important;
    background: #fff !important;
    border: 1.5px solid #e2e8f0 !important;
    border-radius: 16px !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    justify-content: center;
    position: relative !important;
    gap: 10px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    cursor: pointer;
}

#contactUS .fluentform .ff_list_buttons label span::before {
    content: '' !important;
    display: block !important;
    width: 20px;
    height: 20px;
    border: 2px solid #d1d5db;
    border-radius: 50%;
    background-color: #fff;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px;
    transition: all 0.3s ease;
    opacity: 0.6;
    flex-shrink: 0;
}

.fluentform .ff_list_buttons .ff_item_selected label span {
    border-color: var(--primary) !important;
    background-color: rgba(2, 132, 199, 0.03) !important;
    box-shadow: 0 10px 20px rgba(2, 132, 199, 0.1) !important;
    transform: translateY(-3px);
    color: var(--primary) !important;
}

#contactUS .fluentform .ff_list_buttons .ff_item_selected label span::before {
    background-color: var(--primary) !important;
    border-color: var(--primary) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E") !important;
    opacity: 1 !important;
}
@media(max-width:992px) {
    #contactUS .contact-wrap .ff-el-group.ff_list_buttons .ff-el-input--content{display:flex;flex-direction:column;gap:8px!important}
    .list-prgr .ff-el-input--content>div label span{min-height:60px}
    #contactUS .contact-wrap .ff-el-input--content{display:flex;flex-wrap:wrap}
}
@media(max-width:767px){
    #contactUS .contact-wrap{padding:40px 30px}
}
*/
/**************
토글콘텐츠(수학)
**************/
.toggle-container{position:relative;display:flex;background:#e2e8f0;border-radius:60px;padding:6px;max-width:600px;margin:0 auto 3rem;box-shadow:inset 0 2px 4px #0000000d}
.toggle-bg{position:absolute;top:6px;left:6px;width:calc(50% - 6px);height:calc(100% - 12px);background:var(--primary);border-radius:50px;transition:transform .4s cubic-bezier(0.25,1,0.5,1);box-shadow:0 4px 10px #1e3a8a4d;z-index:1}
.toggle-btn{flex:1;position:relative;z-index:2;background:transparent;border:none;padding:1.2rem 0;font-size:1.1rem;font-weight:700;color:var(--text-muted);cursor:pointer;transition:color .3s ease;outline:none}
.toggle-btn.active{color:#fff}
.toggle-container.switched .toggle-bg{transform:translateX(100%)}
.cards-wrapper{position:relative;min-height:480px}
.info-card{position:absolute;top:0;left:0;width:100%;background:var(--surface);border-radius:32px;box-shadow:0 20px 40px #0000000f;border:1px solid #0000000a;display:grid;grid-template-columns:1fr 1.2fr;overflow:hidden;opacity:0;visibility:hidden;transform:translateY(20px);transition:all .5s cubic-bezier(0.16,1,0.3,1);z-index:1}
.info-card.active{opacity:1;visibility:visible;transform:translateY(0);z-index:2;position:relative}
.card-img{width:100%;height:100%;object-fit:cover;min-height:300px}
.card-content{background-color:#fff;padding:3.5rem;display:flex;flex-direction:column;justify-content:center}
.card-badge{align-self:flex-start;padding:.4rem 1rem;border-radius:8px;font-weight:800;font-size:.9rem;margin-bottom:1.5rem}
.badge-free{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}
.badge-paid{background:#fffbeb;color:var(--accent);border:1px solid #fde68a}
.card-title{font-size:2rem;font-weight:800;color:var(--text-main);margin-bottom:1.5rem}
.feature-list{list-style:none;margin-bottom:2rem}
.feature-list li{position:relative;padding-left:1.8rem;margin-bottom:1rem;font-size:1.1rem;color:var(--text-main);line-height:1.6;word-break:keep-all}
.feature-list li::before{content:'✓';position:absolute;left:0;top:0;color:var(--primary);font-weight:900}
.feature-list li strong{color:var(--primary)}
.price-box{background:#f8fafc;border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;margin-top:auto}
.price-row{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0;border-bottom:1px dashed #cbd5e1;font-size:1.1rem}
.price-row:last-child{border-bottom:none;padding-bottom:0}
.price-row.total-info{background:#1e3a8a0d;padding:1rem;border-radius:8px;border:none;margin-bottom:.5rem;color:var(--primary);font-weight:700}
.price-label{font-weight:600;color:var(--text-muted)}
.price-value{font-weight:800;color:var(--text-main)}
.price-notice{font-size:.85rem;color:var(--text-muted);margin-top:1rem;text-align:right}
@media (max-width:768px) {
    .toggle-container{border-radius:16px;padding:4px}
    .toggle-bg{border-radius:12px;top:4px;left:4px;width:calc(50% - 4px);height:calc(100% - 8px)}
    .toggle-btn{font-size:1rem;padding:1rem 0}
    .info-card{grid-template-columns:1fr;border-radius:24px}
    .card-img{min-height:200px;height:200px}
    .card-content{padding:2rem}
    .card-title{font-size:1.6rem}
    .feature-list li{font-size:1rem}
    .price-row{font-size:1rem}
}

/**********
부모안심
**********/
.parent-swiper{width:100%;position:relative;padding:40px 0}
.parent-swiper .swiper-slide{display:flex;justify-content:center;align-items:center;transition:all .4s ease-in-out;transform:scale(0.9);z-index:1}
.parent-swiper .swiper-slide-active{opacity:1;transform:scale(1.15);z-index:10}
.parent-swiper .swiper-slide img{display:block;width:100%;height:auto;object-fit:cover;border-radius:10px;box-shadow:0 5px 15px #0003}
.parent-swiper .swiper-arrow{background:var(--c1);width:60px;height:60px;border-radius:100%;display:flex;align-items:center;justify-content:center}
.parent-swiper .swiper-arrow::after{transform:none;top:auto;bottom:auto;width:100%;height:100%;left:0;display:flex;align-items:center;justify-content:center;margin:0 auto;font-size:29px!important}

/**********
액티비티
**********/
.activity-section{max-width:1200px;margin:0 auto;position:relative;border-radius:32px;overflow:hidden;box-shadow:0 30px 60px #00000026}
.activity-section .hero-wrapper{border-radius:24px;overflow:hidden}
.activity-section .hero-showcase{position:relative;width:100%;height:65vh;min-height:500px;overflow:hidden;display:flex;align-items:flex-end;padding:4rem}
.activity-section .hero-bgs{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.activity-section .hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:scale(1.05);transition:opacity .8s ease-in-out,transform 4s ease-out;z-index:1}
.activity-section .hero-bg.active{opacity:1;transform:scale(1);z-index:2}
.activity-section .hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,#000000e6 0%,#0006 40%,#0000 100%);z-index:0}
.activity-section .hero-content-wrapper{position:relative;z-index:4;width:100%;max-width:800px;display:grid;grid-template-areas: "stack"}
.activity-section .hero-text-box{grid-area: stack; width:100%;opacity:0;transform:translateY(20px);visibility:hidden;transition:all .6s cubic-bezier(0.16,1,0.3,1)}
.activity-section .hero-text-box.active{opacity:1;background:transparent;transform:translateY(0);visibility:visible}
.activity-section .hero-label{display:inline-block;background:var(--accent);color:#fff;padding:.4rem 1rem;border-radius:50px;font-size:.85rem;font-weight:800;letter-spacing:1px;margin-bottom:1rem;text-transform:uppercase}
.activity-section .hero-title{font-size:3rem!important;font-weight:800;color:var(--text-light)!important;margin-bottom:1rem!important;line-height:1.2!important;text-shadow:0 4px 10px #00000080}
.activity-section .hero-desc{font-size:1.2rem!important;color:#ffffffd9!important;line-height:1.6!important;word-break:keep-all!important;text-shadow:0 2px 5px #00000080!important}
.thumbnail-container{position:relative;background:#1e293b;padding:1.5rem 0!important;z-index:5;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}
.thumbnail-container::-webkit-scrollbar{display:none}
.thumbnail-header{color:#fff;font-size:1.1rem;font-weight:700;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}
.thumb-track{display:flex;gap:1rem;overflow-x:visible;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:10px 2rem 1rem;scrollbar-width:none}
.thumb-track::-webkit-scrollbar{display:none}
.thumb-card{flex:0 0 calc(25% - 1rem);min-width:180px;height:120px;position:relative;border-radius:16px;overflow:hidden;cursor:pointer;scroll-snap-align:start;border:2px solid transparent;transition:all .3s ease;opacity:.6}
.thumb-card:hover{opacity:.9}
.thumb-card.active{border-color:var(--accent);opacity:1;transform:translateY(-5px);box-shadow:0 10px 20px #0000004d}
.thumb-card img{width:100%;height:100%;object-fit:cover}
.thumb-overlay{position:absolute;inset:0;background:linear-gradient(to top,#000c 0%,#0000 80%);display:flex;align-items:flex-end;padding:.8rem}
.thumb-title{color:#fff;font-size:.95rem;font-weight:700;text-shadow:0 2px 4px #00000080}
@media (max-width:992px) {
    .hero-showcase{padding:3rem 2rem;height:50vh;min-height:400px}
    #main-container .hero-title{font-size:2.2rem!important}
    .hero-desc{font-size:1rem!important}
    .thumb-card{flex:0 0 calc(40% - 1rem);min-width:140px;height:100px}
}
@media (max-width:480px) {
    .hero-showcase{padding:2rem 1.5rem}
    #main-container .hero-title{font-size:1.8rem!important}
    .thumb-card{flex:0 0 60%;min-width:150px;height:110px}
    .thumbnail-container{padding:1.5rem}
}

/***********
프로세스
***********/
.process-section{background:#ebbebb!important;box-shadow:0 25px 50px -12px #0000000d;border:1px solid #0000000d}
.process-header{margin-bottom:4rem;text-align:center}
.process-header h2{font-size:2.8rem;font-weight:800;color:var(--text-main);line-height:1.3}
.process-header p{font-size:1.1rem;color:#64748b;margin-top:1rem}
.timeline-container{position:relative;padding-left:3rem;max-width:800px;margin:0 auto}
.timeline-line{position:absolute;left:1.5rem;top:0;width:4px;height:100%;background:#f1f5f9;border-radius:4px;transform:translateX(-50%)}
.timeline-progress{position:absolute;left:1.5rem;top:0;width:4px;height:0;background:var(--primary);border-radius:4px;transform:translateX(-50%);transition:height .8s cubic-bezier(0.16,1,0.3,1);z-index:1}
.timeline-container .timeline-item{position:relative;margin-bottom:4rem;opacity:0;transform:translateY(30px);transition:all .6s ease}
.timeline-container .timeline-item:last-child{margin-bottom:0}
.timeline-container .timeline-item.visible{opacity:1;transform:translateY(0)}
.timeline-container .timeline-dot{position:absolute;left:-3rem;top:0;width:40px;height:40px;background:#fff;border:4px solid #e2e8f0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;color:#94a3b8;transform:translateX(-50%);z-index:2;transition:all .5s ease}
.timeline-container .timeline-item.visible .timeline-dot{border-color:var(--primary);background:var(--primary);color:var(--text-light);box-shadow:0 0 20px #1e3a8a4d}
.timeline-content{background:var(--bg-main);padding:2.5rem;border-radius:24px;border:1px solid #f1f5f9}
.step-title{font-size:1.6rem;font-weight:800;color:var(--text-main);margin-bottom:1.5rem;display:flex;align-items:center}
.step-badges{display:flex;flex-wrap:wrap;gap:.8rem}
.step-badge{background:#fbbf24;color:#1e293b;padding:.7rem 1.4rem;border-radius:12px;font-weight:700;font-size:1.05rem;box-shadow:0 4px 6px #fbbf2433;transition:transform .2s ease}
.step-badge:hover{transform:translateY(-2px)}
.step-desc-box{margin-top:1.2rem;background:#fffbeb;padding:1.5rem;border-radius:12px;border-left:4px solid var(--accent);font-size:1rem;line-height:1.6;color:var(--text-main);font-weight:500}
@media (max-width:992px) {
    .process-section{padding:3rem 1.5rem;margin-top:2rem}
    .process-header h2{font-size:2.2rem}
    .timeline-content{padding:1rem 1.2rem}
}
@media (max-width:480px) {
    .process-section{padding:2rem 1rem}
    .timeline-container{padding-left:2rem}
    .timeline-line,.timeline-progress{left:1rem}
    .timeline-dot{left:-2rem;width:32px;height:32px;font-size:.85rem;border-width:3px}
    .timeline-content{padding:1rem 1.2rem}
    .timeline-container .timeline-dot{left:0}
    .step-title{font-size:1.4rem}
    .step-badge{font-size:.95rem;padding:.6rem 1rem}
}

/* ------------------------------------------------
에어비앤비 스타일 벤토(Bento) 그리드
------------------------------------------------ */
.category-block{margin-bottom:5rem}
.category-block:last-child{margin-bottom:0}
.category-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1.5rem;padding:0 .5rem}
.category-title{font-size:1.8rem;font-weight:800;color:var(--text-main)}
.category-subtitle{font-size:1.05rem;color:var(--text-muted);margin-top:.3rem}
.gallery-section .bento-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:250px 250px;gap:1rem;border-radius:24px;overflow:hidden}
.gallery-section .bento-item{position:relative;width:100%;height:100%;overflow:hidden;cursor:pointer;background:#e2e8f0}
.gallery-section .bento-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-section .bento-item:hover img{transform:scale(1.05)}
.gallery-section .bento-item.main{grid-row:1 / span 2;grid-column:1}
.gallery-section .bento-item.sub-1{grid-column:2;grid-row:1}
.gallery-section .bento-item.sub-2{grid-column:3;grid-row:1}
.gallery-section .bento-item.more-btn{grid-column:2 / span 2;grid-row:2}
.more-overlay{position:absolute;inset:0;background:#0f172a99;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;transition:background .3s ease}
.gallery-section .bento-item.more-btn:hover .more-overlay{background:#0f172acc}
.more-icon{font-size:2rem;margin-bottom:.5rem}
.more-text{font-size:1.2rem;font-weight:700;letter-spacing:1px}
@media (max-width:992px) {
    .gallery-section .bento-grid{grid-template-columns:1fr 1fr;grid-template-rows:250px 200px 200px}
    .gallery-section .bento-item.main{grid-column:1 / span 2;grid-row:1}
    .gallery-section .bento-item.sub-1{grid-column:1;grid-row:2}
    .gallery-section .bento-item.sub-2{grid-column:2;grid-row:2}
    .gallery-section .bento-item.more-btn{grid-column:1 / span 2;grid-row:3}
}
@media (max-width:600px) {
    .category-title{font-size:1.5rem}
    .gallery-section .bento-grid{grid-template-rows:200px 150px 150px;gap:.5rem;border-radius:16px}
    .nav-btn{width:40px;height:40px;font-size:1.2rem}
    .nav-prev{left:1rem}
    .nav-next{right:1rem}
}