:root{--bg: #f6f8f7;--surface: #ffffff;--surface-soft: #f9fbfa;--line: #e5ebe8;--text: #20282d;--muted: #7d8a91;--teal: #18b7aa;--teal-dark: #0e978d;--mint: #dff8f3;--coral: #ff746f;--yellow: #f5b526;--blue: #5a99f3;--purple: #8d70df;--green: #36b77b;--cream: #fff8e8;--shadow: 0 16px 45px rgba(35, 48, 55, .08);--shadow-soft: 0 8px 24px rgba(35, 48, 55, .08)}*{box-sizing:border-box}html{background:var(--bg);overflow-x:hidden}body{margin:0;min-width:320px;max-width:100%;overflow-x:hidden;color:var(--text);font-family:Inter,Pretendard,-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Noto Sans KR,Segoe UI,sans-serif;background:radial-gradient(circle at 10% 0%,rgba(24,183,170,.09),transparent 28rem),radial-gradient(circle at 90% 10%,rgba(255,116,111,.08),transparent 24rem),var(--bg)}button,input,select{font:inherit}button{cursor:pointer}.app{min-height:100vh;overflow-x:hidden}.site-header{position:sticky;top:0;z-index:20;background:#ffffffeb;border-bottom:1px solid rgba(226,232,228,.9);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar{max-width:1480px;height:92px;margin:0 auto;padding:0 28px;display:flex;align-items:center;gap:30px}.brand{min-width:278px;display:inline-flex;align-items:center;color:inherit;text-decoration:none}.brand-button{min-height:86px;padding:0;border:0;text-align:left;background:transparent}.brand-logo{width:268px;height:72px;display:block;object-fit:contain;object-position:left center}.search-bar{position:relative;flex:1;max-width:560px}.search-bar input{width:100%;height:48px;padding:0 56px 0 24px;border:1px solid #dce4e1;border-radius:999px;color:var(--text);background:#fff;outline:none;transition:border-color .16s ease,box-shadow .16s ease}.search-bar input:focus{border-color:var(--teal);box-shadow:0 0 0 4px #18b7aa1f}.search-bar button{position:absolute;top:50%;right:8px;width:40px;height:40px;transform:translateY(-50%);border:0;border-radius:999px;color:#1d2429;font-size:24px;background:transparent}.utility-nav{flex:1;display:flex;justify-content:flex-end;align-items:center;gap:8px;color:#313a40;font-size:14px;white-space:nowrap}.utility-nav button{position:relative;min-height:42px;padding:0 10px;border:0;border-radius:12px;color:inherit;background:transparent}.utility-nav b{margin-left:4px;color:var(--teal-dark);font-size:12px}.utility-nav button:hover{background:#f5f8f7}.user-session-badge{min-height:34px;max-width:132px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #cfe8e2;border-radius:999px;color:var(--teal-dark);font-size:13px;font-weight:850;background:#f4fffb}.user-session-full{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.user-session-compact{display:none}.notification-badge{position:absolute;top:3px;right:1px;min-width:18px;height:18px;padding:0 5px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:#fff;font-size:11px;font-weight:800;background:#ff4e54}.layout{max-width:1480px;margin:0 auto;padding:22px 28px 56px;display:grid;grid-template-columns:260px minmax(0,1fr);gap:22px}.sidebar,.sidebar-shell{min-width:0}.mobile-filter-bar,.mobile-filter-close,.filter-scrim{display:none}.filter-panel{position:sticky;top:156px;overflow:visible;padding:20px;border:1px solid var(--line);border-radius:22px;background:#fffffff0;box-shadow:var(--shadow-soft)}.filter-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:16px}.filter-header h2{flex:0 0 auto;margin:0;font-size:17px;letter-spacing:-.03em}.filter-header p{flex:1 1 auto;min-width:0;margin:0;overflow:hidden;color:#52636a;font-size:13px;font-weight:750;white-space:nowrap;text-overflow:ellipsis}.filter-header button{flex:0 0 auto;border:0;color:var(--muted);font-size:13px;background:transparent}.filter-header button:disabled,.save-search-button:disabled{cursor:wait;color:#8a969b;background:#f4f8f7}.filter-list{display:grid;gap:1px}.active-filter-chips{grid-column:1 / -1;min-width:0;display:flex;flex-wrap:wrap;gap:6px;align-items:center}.active-filter-chips>span{color:#68777e;font-size:12px;font-weight:900}.active-filter-chips button{min-height:28px;max-width:220px;padding:0 8px 0 10px;display:inline-flex;align-items:center;gap:5px;overflow:hidden;border:1px solid #dce8e4;border-radius:999px;color:#30554d;font-size:12px;font-weight:800;background:#f6fbf9;white-space:nowrap;text-overflow:ellipsis}.active-filter-chips b{color:#75848a;font-size:14px;line-height:1}.detail-filter-panel{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:8px;padding:8px;border:1px solid #e4ece9;border-radius:12px;background:#f8fcfa}.filter-toggle-button,.detail-filter-toggle{cursor:pointer}.selected-branch-panel{margin-bottom:14px;padding:13px;display:grid;gap:6px;border:1px solid #cfe7e2;border-radius:14px;background:#f2fbf8}.selected-branch-panel span{color:var(--teal-dark);font-size:12px;font-weight:850}.selected-branch-panel strong{color:#1d292e;font-size:15px}.selected-branch-panel small{color:var(--muted);font-size:12px;line-height:1.45}.selected-branch-panel button{width:fit-content;min-height:30px;padding:0 10px;border:1px solid #b7d8d1;border-radius:8px;color:var(--teal-dark);font-size:12px;font-weight:850;background:#fff}.filter-menu-wrap{position:relative}.filter-item{width:100%;padding:15px 0;display:grid;grid-template-columns:28px 1fr 14px;align-items:center;gap:9px;border:0;border-bottom:1px solid #edf1ef;color:inherit;text-align:left;background:transparent}.filter-item:hover,.filter-item.active{color:var(--teal-dark)}.filter-item:disabled{cursor:default;color:inherit;opacity:.72}.filter-menu{margin:-4px 0 8px 37px;padding:10px;overflow:visible;display:grid;gap:8px;border:1px solid #e1e9e6;border-radius:14px;background:#fff;box-shadow:0 8px 22px #1d292e12}.filter-check{min-height:34px;padding:0 8px;display:flex;align-items:center;gap:8px;border-radius:10px;color:#344046;font-size:13px;font-weight:800}.filter-check:hover{background:#f5f8f7}.filter-check input{width:16px;height:16px;accent-color:var(--teal)}.filter-icon{width:28px;height:28px;position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;color:#6f7d84;background:#f5f8f7}.filter-icon span,.filter-icon:before,.filter-icon:after{content:"";position:absolute;box-sizing:border-box;display:block}.filter-icon span{inset:auto}.filter-icon-provider span{width:16px;height:13px;border:2px solid currentColor;border-radius:2px;bottom:5px}.filter-icon-provider:before{width:14px;height:14px;border-left:2px solid currentColor;border-top:2px solid currentColor;top:5px;transform:rotate(45deg)}.filter-icon-provider:after{width:2px;height:2px;background:currentColor;left:9px;bottom:13px;box-shadow:5px 0 0 currentColor,10px 0 0 currentColor,0 5px 0 currentColor,5px 5px 0 currentColor,10px 5px 0 currentColor}.filter-icon-branch span{width:14px;height:14px;border:2px solid currentColor;border-radius:50% 50% 50% 2px;transform:rotate(-45deg)}.filter-icon-branch:after{width:4px;height:4px;border-radius:50%;background:currentColor}.filter-icon-category span{width:5px;height:5px;border-radius:2px;background:currentColor;box-shadow:8px 0 0 currentColor,0 8px 0 currentColor,8px 8px 0 currentColor}.filter-icon-age span{width:8px;height:8px;border:2px solid currentColor;border-radius:50%;top:6px}.filter-icon-age:after{width:16px;height:8px;border:2px solid currentColor;border-radius:10px 10px 4px 4px;border-bottom:0;bottom:6px}.filter-icon-day span{width:16px;height:15px;border:2px solid currentColor;border-radius:4px}.filter-icon-day:before{width:16px;height:2px;background:currentColor;top:10px}.filter-icon-day:after{width:2px;height:4px;background:currentColor;top:5px;left:10px;box-shadow:8px 0 0 currentColor}.filter-icon-date span{width:16px;height:15px;border:2px solid currentColor;border-radius:4px}.filter-icon-date:before{width:16px;height:2px;background:currentColor;top:10px}.filter-icon-date:after{width:3px;height:3px;border-radius:50%;background:currentColor;left:10px;bottom:8px;box-shadow:5px 0 0 currentColor}.filter-icon-time span{width:17px;height:17px;border:2px solid currentColor;border-radius:50%}.filter-icon-time:before{width:2px;height:6px;background:currentColor;top:8px}.filter-icon-time:after{width:6px;height:2px;background:currentColor;left:14px;top:14px}.filter-icon-fee:before{content:"₩";position:static;width:auto;height:auto;background:transparent;color:currentColor;font-size:16px;font-weight:950;line-height:1}.filter-icon-fee span,.filter-icon-fee:after{display:none}.filter-icon-status span{width:17px;height:17px;border:2px solid currentColor;border-radius:50%}.filter-icon-status:after{width:7px;height:4px;border-left:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg)}.filter-item.active .filter-icon,.filter-item:hover .filter-icon{color:var(--teal-dark);background:#18b7aa1c}.age-month-input,.date-filter-input{min-height:44px;padding:8px 12px 8px 37px;display:grid;gap:6px;color:#344046;font-size:12px;font-weight:850}.date-filter-item{cursor:default;grid-template-columns:28px 1fr 36px}.date-filter-item input{width:36px;height:36px;padding:0;justify-self:end;border:1px solid var(--line);border-radius:10px;color:transparent;background:#fff}.date-filter-item input::-webkit-calendar-picker-indicator{width:18px;height:18px;margin:0 8px;cursor:pointer;opacity:.72}.date-filter-item:focus-within .filter-icon,.date-filter-item:hover .filter-icon{color:var(--teal-dark);background:#18b7aa1c}.age-month-input input,.date-filter-input input{width:100%;height:36px;padding:0 12px;border:1px solid var(--line);border-radius:10px;color:#263238;font-size:14px;font-weight:800;background:#fff}.age-month-input input:focus,.date-filter-input input:focus{outline:2px solid rgba(24,183,170,.18);border-color:#18b7aa8c}.age-month-input.in-filter-menu{margin-top:8px;padding:10px 8px 2px;border-top:1px solid rgba(226,232,228,.9)}.filter-copy{display:grid;gap:4px}.filter-copy strong{font-size:14px}.filter-copy small{color:var(--muted);font-size:12px}.filter-chevron{color:#a0a9ad;font-size:24px}.map-search-toggle{position:relative;margin:20px 0 16px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:800}.map-search-toggle input{position:absolute;inline-size:1px;block-size:1px;opacity:0}.switch{position:relative;width:44px;height:26px;border-radius:999px;background:#d6dfdc;transition:background .16s ease}.switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0000002e;transition:transform .16s ease}.map-search-toggle input:checked+.switch{background:var(--teal)}.map-search-toggle input:checked+.switch:after{transform:translate(18px)}.save-search-button{width:100%;height:50px;border:1px solid var(--line);border-radius:14px;color:#2d383d;font-weight:850;background:#fff}.save-search-button:hover{border-color:#18b7aa73;color:var(--teal-dark);background:#f5fcfa}.save-search-button.secondary{margin-top:8px;color:var(--teal-dark);background:#f2fbf8}.main-content{min-width:0}.map-tabs{margin-bottom:8px;display:inline-flex;gap:4px;padding:4px;border:1px solid var(--line);border-radius:12px;background:#fff;box-shadow:var(--shadow-soft)}.map-tabs button{min-height:34px;padding:0 14px;border:0;border-radius:9px;color:#536168;font-weight:850;background:transparent;cursor:pointer}.map-tabs button.active{color:#fff;background:var(--teal-dark)}.map-card{overflow:hidden;border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--shadow)}.google-map-card{position:relative;height:420px}.google-map-card>div:first-child{min-height:420px}.google-map-fallback{min-height:360px;padding:28px;display:grid;place-content:center;justify-items:center;gap:12px;text-align:center;color:#4d5a60;background:#eef4ef}.google-map-fallback strong{color:#1d292e;font-size:18px}.google-map-fallback span{max-width:520px;line-height:1.5}.google-map-fallback button{height:42px;padding:0 16px;border:0;border-radius:999px;color:#fff;font-weight:850;background:var(--teal)}.google-map-fallback em,.google-map-fallback.error strong{color:#b64a4a;font-style:normal}.google-map-location-button,.google-map-status{position:absolute}.map-inline-error{position:absolute;right:14px;bottom:14px;z-index:5;max-width:min(360px,calc(100% - 28px));padding:9px 11px;border:1px solid #ffd0d0;border-radius:12px;color:#a23d3d;font-size:12px;font-weight:800;background:#fff6f6f0;box-shadow:var(--shadow-soft)}.map-info-window{max-width:220px;display:grid;gap:4px;color:#344046;font-size:12px;line-height:1.4}.map-info-window strong{color:#1d292e;font-size:14px}.map-category-chips{margin-top:4px;display:flex;flex-wrap:wrap;gap:4px}.map-category-chip{padding:2px 6px;border:1px solid #dce7e3;border-radius:999px;color:#263238;font-size:11px;font-weight:800;background:#fff}.map-category-legend{position:absolute;left:14px;top:14px;z-index:5;max-width:min(520px,calc(100% - 28px));display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid rgba(218,228,225,.92);border-radius:12px;background:#fffffff0;box-shadow:var(--shadow-soft)}.map-category-legend span{display:inline-flex;align-items:center;gap:5px;color:#263238;font-size:11px;font-weight:850;white-space:nowrap}.map-category-legend i{width:9px;height:9px;border-radius:999px;box-shadow:0 0 0 2px #ffffffe6}.map-canvas{position:relative;min-height:315px;overflow:hidden;isolation:isolate;background:linear-gradient(90deg,rgba(80,146,255,.08) 1px,transparent 1px),linear-gradient(0deg,rgba(80,146,255,.08) 1px,transparent 1px),radial-gradient(circle at 64% 22%,rgba(90,211,168,.22),transparent 12rem),radial-gradient(circle at 21% 68%,rgba(255,204,118,.24),transparent 13rem),#eef4ef;background-size:42px 42px,42px 42px,auto,auto,auto}.river{position:absolute;right:-8%;bottom:0;left:-8%;top:-42%;height:140px;transform:rotate(-5deg);border-bottom:8px solid rgba(103,188,213,.35);background:linear-gradient(180deg,#89d4e67a,#89d4e629);z-index:-1}.road{position:absolute;border-radius:999px;background:#ffffffeb;box-shadow:0 0 0 2px #f0c56459}.road-main{height:14px;background:#fffaf0;box-shadow:0 0 0 3px #f5b52652}.road-sub{height:8px;background:#fffffff2;box-shadow:0 0 0 1px #c4ccc78c}.road-1{width:72%;left:-6%;top:57%;transform:rotate(-12deg)}.road-2{width:65%;right:-8%;top:38%;transform:rotate(18deg)}.road-3{width:52%;left:9%;top:26%;transform:rotate(6deg)}.road-4{width:48%;right:13%;top:72%;transform:rotate(-9deg)}.road-5{width:38%;left:43%;top:50%;transform:rotate(86deg)}.map-label{position:absolute;padding:3px 7px;border-radius:999px;color:#4b5c62b8;font-size:12px;font-weight:700;background:#ffffff8f;transform:translate(-50%,-50%)}.map-empty{position:absolute;left:50%;top:50%;padding:10px 14px;transform:translate(-50%,-50%);border:1px solid rgba(226,232,228,.9);border-radius:999px;color:#59656a;font-size:13px;font-weight:800;background:#ffffffe6;box-shadow:var(--shadow-soft)}.user-location-marker{position:absolute;width:18px;height:18px;transform:translate(-50%,-50%);border:3px solid #fff;border-radius:999px;background:#1c7df2;box-shadow:0 0 0 7px #1c7df226,0 8px 18px #12325a47;z-index:4}.user-location-marker span{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border:2px solid rgba(28,125,242,.26);border-radius:999px}.map-pin{position:absolute;width:34px;height:34px;transform:translate(-50%,-88%);border:3px solid #fff;border-radius:999px 999px 999px 6px;color:#fff;font-size:13px;font-weight:900;box-shadow:0 8px 18px #26373c38;rotate:-45deg;z-index:3}.map-pin{display:inline-flex;align-items:center;justify-content:center}.map-pin>span{position:relative;z-index:1;rotate:45deg}.map-pin:before{content:"";position:absolute;top:9px;right:9px;bottom:9px;left:9px;border-radius:999px;border:2px solid rgba(255,255,255,.78)}.map-pin:after{content:attr(aria-label);position:absolute;top:36px;left:50%;width:max-content;max-width:130px;padding:5px 8px;transform:translate(-50%) rotate(45deg);border:1px solid rgba(226,232,228,.8);border-radius:999px;color:#415057;font-size:11px;font-weight:750;background:#ffffffeb;opacity:0;pointer-events:none;transition:opacity .14s ease,translate .14s ease}.map-pin:hover:after{opacity:1;translate:0 2px}.pin-mint{background:var(--teal)}.pin-coral{background:var(--coral)}.pin-yellow{background:var(--yellow)}.pin-blue{background:var(--blue)}.pin-purple{background:var(--purple)}.pin-green{background:var(--green)}.search-area-button,.view-toggle,.zoom-control{position:absolute;z-index:5}.search-area-button{top:18px;left:18px;height:44px;padding:0 18px;border:1px solid #dce6e3;border-radius:14px;color:#253137;font-size:14px;font-weight:850;background:#ffffffeb;box-shadow:var(--shadow-soft)}.search-area-button:disabled{cursor:wait;color:#7d8a91;background:#f4f8f7f0}.google-map-approx-button{top:70px;left:18px}.map-status-panel{position:absolute;left:18px;bottom:18px;z-index:5;max-width:min(340px,calc(100% - 120px));padding:12px 14px;display:grid;gap:4px;border:1px solid #dce6e3;border-radius:14px;color:#48565d;font-size:12px;font-weight:700;background:#fffffff0;box-shadow:var(--shadow-soft)}.map-status-panel strong{color:#1d292e;font-size:14px}.map-status-panel em{color:#b64a4a;font-style:normal}.view-toggle{top:18px;right:18px;padding:4px;display:flex;gap:3px;border:1px solid #dde7e4;border-radius:999px;background:#fffffff0;box-shadow:var(--shadow-soft)}.view-toggle button{min-width:74px;height:38px;border:0;border-radius:999px;color:#68757b;font-weight:850;background:transparent}.view-toggle button.active{color:var(--teal-dark);background:#eafbf8;box-shadow:inset 0 0 0 1px #18b7aa42}.zoom-control{right:24px;bottom:24px;overflow:hidden;display:grid;border:1px solid #dce6e3;border-radius:14px;background:#fff;box-shadow:var(--shadow-soft)}.zoom-control button{width:44px;height:42px;border:0;color:#222f34;font-size:24px;background:#fff}.zoom-control button+button{border-top:1px solid #edf1ef}.section{margin-top:22px}.section-header{margin-bottom:14px;display:flex;align-items:end;justify-content:space-between;gap:20px}.eyebrow,.section-subtitle{margin:0;color:var(--muted);font-size:13px}.section-header h2{margin:2px 0 0;color:#1d292e;font-size:21px;letter-spacing:-.04em}.section-header h2 strong{color:var(--teal-dark)}.sort-select{min-width:114px;height:42px;padding:0 14px;border:1px solid var(--line);border-radius:12px;color:#344046;background:#fff}.class-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}.branch-course-groups{display:grid;gap:14px}.branch-course-group{padding:10px 12px 14px;display:grid;grid-template-columns:minmax(0,1fr);gap:10px;align-items:stretch;border:1px solid #e4ece9;border-radius:14px;background:#ffffffd6}.branch-course-group-header{grid-column:1 / -1;margin-bottom:0;min-width:0;width:100%;min-height:36px;padding:0 0 8px;border:0;border-bottom:1px solid #e4ece9;display:flex;align-items:center;color:inherit;font:inherit;text-align:left;background:transparent;cursor:pointer}.branch-course-group-header:hover h3,.branch-course-group-header:focus-visible h3{color:var(--teal-dark)}.branch-course-group-header:focus-visible{outline:2px solid rgba(18,152,134,.36);outline-offset:3px}.branch-course-group-title{min-width:0;display:flex;width:100%;align-items:center;gap:8px}.branch-course-group-header h3{flex:1 1 auto;margin:0;min-width:0;overflow:hidden;color:#1d292e;font-size:15px;line-height:1.3;letter-spacing:0;white-space:nowrap;text-overflow:ellipsis}.branch-course-group-title .provider-badge{flex:0 0 auto}.branch-course-group-title strong{flex:0 0 auto;margin-left:auto;width:fit-content;min-height:26px;padding:5px 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:var(--teal-dark);font-size:13px;font-weight:900;background:#eefaf7}.branch-course-group.is-expanded .branch-course-group-header{padding-bottom:8px}.branch-course-group.is-expanded .branch-class-grid{max-height:172px}.branch-course-group.is-expanded .branch-class-grid .class-card{width:100%}.class-grid.branch-class-grid{min-width:0;max-height:172px;display:grid;grid-template-columns:minmax(0,1fr);grid-auto-rows:158px;gap:12px;overflow-x:hidden;overflow-y:auto;padding:2px 10px 12px 2px;align-items:stretch;scrollbar-gutter:stable;scroll-snap-type:y proximity;overscroll-behavior:contain}.branch-course-group:not(.is-expanded) .branch-class-grid{grid-template-columns:minmax(0,1fr);max-height:172px}.branch-course-group.is-expanded .branch-class-grid{grid-template-columns:repeat(auto-fill,minmax(min(100%,340px),1fr))}.branch-class-grid .class-card{width:100%;height:158px;min-height:0;display:grid;grid-template-columns:96px minmax(0,1fr);border-radius:14px;scroll-snap-align:start}.branch-class-grid .class-thumb{height:100%;min-height:0}.branch-class-grid .thumb-emoji{font-size:38px}.branch-class-grid .favorite-button{top:7px;right:7px;width:30px;height:30px;font-size:16px}.branch-class-grid .status-badge{left:7px;bottom:7px;padding:4px 7px;font-size:10px}.branch-class-grid .class-body{min-width:0;padding:10px 12px}.branch-class-grid .class-title-row h3{min-height:0;overflow:hidden;display:-webkit-box;color:#19252b;font-size:14.5px;line-height:1.25;letter-spacing:0;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-class-grid .age-text{margin:5px 0 6px;padding:4px 7px;gap:5px;font-size:11.5px}.branch-class-grid .age-text span{font-size:10px}.branch-class-grid .class-meta{gap:4px;font-size:11.5px}.branch-class-grid .class-meta .meta-row-priority{grid-template-columns:34px 1fr;padding:5px 7px}.branch-class-grid .class-meta .meta-row-priority dd{font-size:12px}.branch-class-grid .class-footer{margin-top:8px;gap:8px}.branch-class-grid .class-footer strong{font-size:14px;letter-spacing:0}.branch-class-grid .class-footer button{min-height:29px;padding:0 9px;font-size:11.5px}.branch-class-grid::-webkit-scrollbar{width:10px}.branch-class-grid::-webkit-scrollbar-track{border-radius:999px;background:#eef3f1}.branch-class-grid::-webkit-scrollbar-thumb{border:2px solid #eef3f1;border-radius:999px;background:#b8cbc4}.branch-course-groups{gap:8px}.branch-course-group{padding:0;gap:0;overflow:hidden;border-radius:8px;background:#fff}.branch-course-group-header{min-height:60px;padding:10px 12px;border-bottom:0;display:grid;grid-template-columns:minmax(180px,1.35fr) minmax(260px,2fr) auto;gap:10px;align-items:center}.branch-course-group-header:hover{background:#f7fcfa}.branch-course-group-title{gap:7px}.branch-course-group-header h3{font-size:14px}.branch-course-group-title strong{min-height:23px;padding:4px 8px;font-size:12px}.branch-course-group-summary{min-width:0;display:flex;flex-wrap:wrap;gap:5px;align-items:center;color:#55656c;font-size:12px;font-weight:750;line-height:1.25}.branch-course-group-summary span{max-width:180px;min-height:22px;padding:3px 7px;overflow:hidden;border-radius:999px;background:#f1f6f4;white-space:nowrap;text-overflow:ellipsis}.branch-course-group-toggle{min-width:52px;min-height:28px;padding:5px 9px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #dce8e4;border-radius:999px;color:#315047;font-size:12px;font-weight:900;background:#fff}.branch-course-group.is-expanded .branch-course-group-header{border-bottom:1px solid #e4ece9}.branch-course-preview{padding:0 8px 8px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:7px}.branch-course-preview-item{min-width:0;min-height:54px;padding:8px 9px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:3px 7px;align-items:center;border:1px solid #e6eeeb;border-radius:8px;color:#2a373d;text-align:left;background:#fbfdfc}.branch-course-preview-item:hover{border-color:#18b7aa52;background:#f5fbf9}.branch-course-preview-item.is-closed strong{color:#9aa3a8}.preview-status{grid-row:1 / span 2;min-height:22px;padding:3px 6px;border-radius:999px;color:#08796e;font-size:10.5px;font-weight:900;background:#dffff8}.branch-course-preview-item strong{min-width:0;overflow:hidden;color:#19252b;font-size:13px;line-height:1.25;white-space:nowrap;text-overflow:ellipsis}.branch-course-preview-item span:not(.preview-status){min-width:0;overflow:hidden;color:#617078;font-size:11.5px;font-weight:700;white-space:nowrap;text-overflow:ellipsis}.branch-course-preview-item em{grid-column:3;grid-row:1 / span 2;color:#1d292e;font-size:12px;font-style:normal;font-weight:900;white-space:nowrap}.branch-course-group.is-expanded .branch-class-grid,.class-grid.branch-class-grid{max-height:520px;grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;gap:7px;padding:8px;overflow-x:hidden;overflow-y:auto;scroll-snap-type:y proximity}.branch-class-grid .class-card{min-height:0;height:auto;display:grid;grid-template-columns:minmax(0,1fr);border-radius:8px;box-shadow:none;scroll-snap-align:start}.branch-class-grid .class-card:hover{transform:none}.branch-class-grid .class-thumb{display:none}.branch-class-grid .class-body{padding:9px 11px;display:grid;grid-template-columns:minmax(0,1.5fr) minmax(210px,1fr) auto;gap:8px 12px;align-items:center}.branch-class-grid .class-title-row{min-width:0}.branch-class-grid .class-title-row h3{min-height:0;font-size:14px;line-height:1.25;-webkit-line-clamp:2}.branch-class-grid .age-text{grid-column:1;margin:0;padding:0;gap:5px;border-radius:0;background:transparent;font-size:12px}.branch-class-grid .age-text span{font-size:11px}.branch-class-grid .class-meta{grid-column:2;grid-row:1 / span 2;gap:4px;font-size:12px}.branch-class-grid .class-meta>div:not(.meta-row-schedule){display:none}.branch-class-grid .class-meta .meta-row-priority{padding:0;grid-template-columns:34px minmax(0,1fr);border:0;background:transparent}.branch-class-grid .class-meta .meta-row-priority dd{min-width:0;font-size:12px}.branch-class-grid .schedule-line{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.branch-class-grid .class-footer{grid-column:3;grid-row:1 / span 2;margin-top:0;min-width:96px;flex-direction:column;align-items:flex-end;justify-content:center;gap:5px}.branch-class-grid .class-footer strong{font-size:13px}.branch-class-grid .class-footer button{min-height:28px;padding:0 9px;font-size:11px}.class-card{overflow:hidden;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 4px 18px #1d292e0d;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.class-card-clickable{cursor:pointer}.class-card-clickable:focus-visible{outline:3px solid rgba(24,183,170,.35);outline-offset:3px}.class-card:hover{transform:translateY(-3px);border-color:#18b7aa3d;box-shadow:var(--shadow-soft)}.class-thumb,.popular-thumb{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;isolation:isolate}.class-thumb{height:154px}.class-thumb:before,.popular-thumb:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(255,255,255,.7),transparent 24%),radial-gradient(circle at 80% 15%,rgba(255,255,255,.42),transparent 22%),radial-gradient(circle at 50% 100%,rgba(0,0,0,.08),transparent 35%);z-index:-1}.thumb-art{background:linear-gradient(135deg,#ffe8da,#d9fff6 55%,#fff7c7)}.thumb-cooking{background:linear-gradient(135deg,#fff2d7,#ffd1bc 55%,#c7f1dc)}.thumb-yoga{background:linear-gradient(135deg,#e8f4ff,#f7efff 55%,#e9fff7)}.thumb-pottery{background:linear-gradient(135deg,#e4d0bd,#f3e7db 55%,#c8b39d)}.thumb-music{background:linear-gradient(135deg,#fff4f6,#e1f6ff 55%,#ffe5ad)}.thumb-ballet{background:linear-gradient(135deg,#fff0f8,#f6d6ff 55%,#fdf4ff)}.thumb-swim{background:linear-gradient(135deg,#d8f6ff,#b7e6ff 55%,#eefcff)}.thumb-coffee{background:linear-gradient(135deg,#f8e5cd,#c89b6d 55%,#fff8ef)}.thumb-emoji{font-size:64px;filter:drop-shadow(0 10px 14px rgba(31,46,54,.16))}.course-image{width:100%;height:100%;display:block;object-fit:cover}.class-thumb:has(.course-image):before,.popular-thumb:has(.course-image):before{display:none}.favorite-button{position:absolute;top:12px;right:12px;width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(214,224,220,.8);border-radius:50%;color:#657278;font-size:20px;background:#ffffffe0;box-shadow:0 7px 14px #25313714}.favorite-button.active{color:#fff;border-color:#ff746f66;background:#ff746f}.status-badge{position:absolute;left:12px;bottom:12px;padding:6px 9px;border-radius:999px;color:#08796e;font-size:12px;font-weight:900;background:#dffff8}.class-body{padding:15px 15px 16px}.class-title-row{display:flex;align-items:start;justify-content:space-between;gap:10px}.class-title-row h3,.popular-copy h3{margin:0;color:#19252b;letter-spacing:-.04em}.class-title-row h3{min-height:44px;font-size:17px;line-height:1.3}.class-card.is-closed .class-title-row h3,.popular-card.is-closed .popular-copy h3,.closed-title{color:#9aa3a8}.source-chip{min-width:26px;height:26px;display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;border-radius:8px;font-size:13px;font-weight:900}.provider-badge{min-height:21px;padding:3px 7px;display:inline-flex;align-items:center;border-radius:7px;font-size:11px;font-style:normal;font-weight:900;line-height:1;white-space:nowrap}.source-h{color:#168164;background:#e0f6ed;box-shadow:inset 0 0 0 1px #b8e9d5}.source-l{color:#db5b73;background:#ffebef;box-shadow:inset 0 0 0 1px #ffd0d9}.source-e{color:#2c78ba;background:#e6f3ff;box-shadow:inset 0 0 0 1px #c7e4ff}.source-hd{color:#1d4ed8;background:#e0ecff;box-shadow:inset 0 0 0 1px #bfdbfe}.source-g,.source-er{color:#fff;background:#111827;box-shadow:inset 0 0 0 1px #111827}.source-s{color:#fff;background:#dc2626;box-shadow:inset 0 0 0 1px #b91c1c}.source-a{color:#6d28d9;background:#f0e7ff;box-shadow:inset 0 0 0 1px #ddd6fe}.source-m{color:#4a3510;background:#fff3bf;box-shadow:inset 0 0 0 1px #fde68a}.pin-black{background:#111827}.age-text{width:fit-content;max-width:100%;margin:4px 0 11px;padding:7px 10px;display:flex;flex-wrap:wrap;align-items:center;gap:6px;border-radius:8px;color:#6a3f13;font-size:13px;background:#fff7e6;box-shadow:inset 0 0 0 1px #efd9a8}.age-text span{font-size:11px;font-weight:850;color:#8a672d}.age-text strong,.popular-age-text strong,.detail-age-badge{color:#4f320d;font-weight:900}.popular-age-text,.popular-category-text,.popular-branch-text{color:#6a3f13}.popular-category-text,.popular-branch-text{color:#6a767c}.popular-branch-text{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.detail-age-badge{min-height:26px;padding:5px 9px;display:inline-flex;align-items:center;border-radius:8px;background:#fff7e6;box-shadow:inset 0 0 0 1px #efd9a8}.class-tags{margin:8px 0 7px;display:flex;flex-wrap:wrap;gap:6px}.class-tags span{min-height:24px;display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;color:#31545c;font-size:12px;font-weight:850;background:#edf7f4;box-shadow:inset 0 0 0 1px #d2e9e1}.class-tags.compact{margin:6px 0 5px}.class-tags.compact span{min-height:21px;padding:3px 7px;font-size:11px}.class-meta{margin:0;display:grid;gap:7px;color:#4d5a60;font-size:12.5px;line-height:1.35}.class-meta div{display:grid;grid-template-columns:34px 1fr;gap:6px}.class-meta dt{color:#8a969b;font-weight:750}.class-meta dd{margin:0}.class-meta .meta-row-priority{grid-template-columns:38px 1fr;padding:7px 8px;border-radius:8px;background:#f7fbfa;box-shadow:inset 0 0 0 1px #dcebe6}.class-meta .meta-row-priority dt{color:#31545c;font-weight:900}.class-meta .meta-row-priority dd{color:#1d292e;font-size:13px;font-weight:850}.class-meta .meta-row-schedule{background:#eefbf8;box-shadow:inset 0 0 0 1px #cbeee6}.schedule-line{display:block;line-height:1.35}.schedule-date{color:#1d292e;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.schedule-time{margin-top:2px;color:#4f6269;font-weight:800}.schedule-combined{color:#2e3d43;font-weight:850}.class-meta .meta-row-branch{background:#fffaf0;box-shadow:inset 0 0 0 1px #f0dfb8}.class-meta .meta-row-instructor{margin-top:1px;color:#758287}.branch-with-provider{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.class-footer{margin-top:14px;display:flex;align-items:center;justify-content:space-between;gap:12px}.class-footer strong{color:#1d292e;font-size:18px;letter-spacing:-.03em}.class-footer button{min-height:34px;padding:0 12px;border:0;border-radius:999px;color:#fff;font-size:12px;font-weight:900;background:var(--teal)}.class-footer button:hover{background:var(--teal-dark)}.class-footer button:disabled{cursor:not-allowed;color:#7d8a91;background:#e8eeeb}.class-actions{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.class-actions .compare-action{color:#2e3d43;background:#edf5f2;box-shadow:inset 0 0 0 1px #d4e5df}.class-actions .compare-action:hover{background:#deece7}.class-actions .compare-action.active{color:#fff;background:#475569;box-shadow:none}.class-actions .apply-action.active{color:#8a4b00;background:#fff4d7;box-shadow:inset 0 0 0 1px #ebd391}.class-actions .apply-action.active:hover{background:#ffe8ad}.state-panel{margin-bottom:16px;padding:18px 20px;border:1px solid var(--line);border-radius:16px;color:#59656a;font-weight:800;background:#fff}.state-panel.error{border-color:#ffd0d0;color:#a23d3d;background:#fff6f6}.course-compare-panel{margin-bottom:16px;padding:14px;border:1px solid #d7e4de;border-radius:8px;background:#fbfefd;box-shadow:0 8px 22px #1f303614}.course-compare-header{margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.course-compare-header h3{margin:2px 0 0;color:#17242a;font-size:18px;line-height:1.25}.course-compare-header h3 strong{color:var(--teal-dark)}.course-compare-header button,.compare-remove-button{min-height:30px;padding:0 10px;border:1px solid #d4e1dc;border-radius:999px;color:#435158;font-size:12px;font-weight:900;background:#fff;cursor:pointer}.course-compare-table-wrap{overflow-x:auto;border:1px solid #e3ece8;border-radius:8px;background:#fff}.course-compare-table-wrap-mobile{display:none}.course-compare-table{width:100%;min-width:720px;table-layout:fixed;border-collapse:collapse;color:#2e3d43;font-size:12.5px}.course-compare-table th,.course-compare-table td{width:190px;padding:9px 10px;border-bottom:1px solid #edf3f0;border-right:1px solid #edf3f0;overflow:hidden;vertical-align:top;text-align:left;overflow-wrap:anywhere}.course-compare-table th:first-child,.course-compare-table td:first-child{width:86px;color:#6c7a80;font-weight:950;background:#f8fbfa;position:sticky;left:0;z-index:1}.course-compare-table thead th{background:#f3f8f6}.course-compare-table tbody tr:last-child th,.course-compare-table tbody tr:last-child td{border-bottom:0}.compare-title-button{width:100%;min-width:0;padding:0;border:0;display:grid;gap:4px;color:#17242a;text-align:left;background:transparent;cursor:pointer}.compare-title-button span{display:-webkit-box;overflow:hidden;max-width:100%;font-size:13px;font-weight:950;line-height:1.28;-webkit-line-clamp:2;-webkit-box-orient:vertical}.compare-title-button small{overflow:hidden;max-width:100%;color:#6c7a80;font-size:11.5px;font-weight:850;white-space:nowrap;text-overflow:ellipsis}.compare-remove-button{margin-top:8px;min-height:26px;padding:0 8px;color:#8b4a4a;border-color:#f1d8d8;background:#fff8f8}@media (max-width: 640px){.course-compare-panel{padding:10px}.course-compare-header{align-items:flex-start}.course-compare-header h3{font-size:16px}.course-compare-table-wrap-desktop{display:none}.course-compare-table-wrap-mobile{display:block}.course-compare-table-transposed{min-width:980px;table-layout:fixed}.course-compare-table-transposed th,.course-compare-table-transposed td{width:104px;padding:8px;font-size:12px}.course-compare-table-transposed th:first-child,.course-compare-table-transposed td:first-child{width:170px}.course-compare-table-transposed th:last-child,.course-compare-table-transposed td:last-child{width:68px}.course-compare-table-transposed thead th:first-child,.course-compare-table-transposed tbody th:first-child{position:sticky;left:0;z-index:2;background:#f8fbfa}.course-compare-table-transposed .compare-title-button span{font-size:12.5px;-webkit-line-clamp:3}.course-compare-table-transposed .compare-remove-button{margin-top:0;min-height:28px;padding:0 7px;font-size:11.5px}}.result-progress{margin:6px 0 0;color:var(--muted);font-size:13px;font-weight:800}.popular-section{padding:20px;border:1px solid #f5e8c8;border-radius:24px;background:linear-gradient(135deg,#fffaedf5,#ffffffd1),var(--cream);box-shadow:var(--shadow-soft)}.text-button{border:0;color:#38454b;font-weight:850;background:transparent}.popular-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.popular-card{position:relative;min-height:120px;padding:13px 12px 13px 92px;display:flex;align-items:center;border:1px solid rgba(231,225,214,.98);border-radius:20px;background:#fffffff0;box-shadow:0 10px 22px #3f31180f}.popular-card-button{width:100%;color:inherit;text-align:left;cursor:pointer}.popular-card-button:hover{border-color:#18b7aa47;box-shadow:var(--shadow-soft)}.toast{position:fixed;top:148px;right:28px;z-index:40;max-width:min(360px,calc(100vw - 40px));padding:12px 15px;border:1px solid rgba(24,183,170,.24);border-radius:14px;color:#1d292e;font-size:13px;font-weight:800;background:#fffffff5;box-shadow:var(--shadow-soft)}.notification-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#151f243d}.notification-panel{position:absolute;top:86px;right:28px;width:min(420px,calc(100vw - 32px));max-height:min(620px,calc(100vh - 110px));display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow)}.notification-panel-header{padding:18px;display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line)}.notification-panel-header h2{margin:0;font-size:19px}.notification-panel-header p{margin:5px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.notification-panel-actions{display:flex;align-items:start;gap:6px}.notification-panel-actions button{min-height:32px;padding:0 9px;border:1px solid var(--line);border-radius:8px;color:#263238;font-size:12px;font-weight:800;background:#fff}.notification-list{margin:0;padding:8px;overflow-y:auto;list-style:none}.notification-list li+li{margin-top:6px}.notification-list button{width:100%;padding:12px;display:grid;grid-template-columns:auto 1fr;gap:5px 9px;border:1px solid transparent;border-radius:12px;color:#1d292e;text-align:left;background:#f8fbfa}.notification-list button:hover{border-color:#18b7aa47;background:#f3fbf8}.notification-type{grid-row:span 3;min-width:46px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:#fff;font-size:11px;font-weight:900;background:var(--teal)}.notification-type.type-deadline{background:#e64c4c}.notification-type.type-course_start{background:#5768d8}.notification-type.type-start{background:#c58319}.notification-list strong{font-size:14px}.notification-list span:not(.notification-type){color:#4d5a60;font-size:13px;line-height:1.4}.notification-list time{color:var(--teal-dark);font-size:12px;font-weight:850}.notification-empty{padding:34px 20px;color:var(--muted);font-size:14px;font-weight:800;text-align:center}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;display:grid;place-items:center;padding:24px;background:#151f246b}.login-modal{width:min(420px,100%);padding:22px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow)}.course-detail-backdrop{z-index:80;overflow-y:auto;align-items:start}.course-detail-modal{position:relative;width:min(760px,100%);max-height:calc(100vh - 48px);overflow:hidden auto;border:1px solid var(--line);border-radius:22px;background:#fff;box-shadow:var(--shadow)}.modal-close-button{position:absolute;top:14px;right:14px;z-index:2;width:38px;height:38px;border:0;border-radius:999px;color:#253137;font-size:26px;line-height:1;background:#ffffffe6;box-shadow:0 8px 18px #1d292e1f}.course-detail-hero{position:relative;min-height:260px;max-height:320px;padding:14px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#f2f8f6f5,#ffffffd1),#eef4f2}.course-detail-image{width:100%;height:100%;max-height:292px;object-fit:contain;display:block;border-radius:14px}.course-detail-emoji{font-size:84px}.detail-status{bottom:16px;left:16px}.course-detail-content{padding:22px}.course-detail-title-row{display:flex;justify-content:space-between;gap:18px}.course-detail-title-row h2{margin:4px 0 0;color:#19252b;font-size:25px;line-height:1.28;letter-spacing:-.03em}.detail-favorite{position:static;flex:0 0 auto}.course-detail-list{margin:20px 0 0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.course-detail-list div{min-width:0;padding:11px 12px;border:1px solid #edf2ef;border-radius:12px;background:#fbfdfc}.course-detail-list dt{margin-bottom:4px;color:#7d8a91;font-size:12px;font-weight:850}.course-detail-list dd{margin:0;color:#263238;font-size:14px;line-height:1.4;word-break:keep-all}.course-detail-list .schedule-lines-detail{display:block}.course-detail-description{margin-top:18px;padding:16px;border-radius:14px;background:#f7faf9}.course-detail-description h3{margin:0 0 8px;color:#243137;font-size:16px}.course-detail-description p{margin:0;color:#4d5a60;font-size:14px;line-height:1.65;white-space:pre-wrap}.course-detail-ai{margin-top:12px;padding:14px 16px;display:grid;gap:12px;border-radius:14px;background:#fffaf0;box-shadow:inset 0 0 0 1px #f0dfb8}.course-detail-ai h3{margin:0 0 7px;color:#4f320d;font-size:14px;font-weight:900}.course-detail-ai p{margin:0;color:#4d4638;font-size:14px;line-height:1.6;white-space:pre-wrap}.course-detail-tags{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}.course-detail-ai .course-detail-tags{margin-top:0}.course-detail-tags span{min-height:28px;padding:5px 10px;display:inline-flex;align-items:center;border-radius:999px;color:#31545c;font-size:12px;font-weight:850;background:#edf7f4;box-shadow:inset 0 0 0 1px #d2e9e1}.course-detail-tags.ai-tags span{color:#6a3f13;background:#fff4d7;box-shadow:inset 0 0 0 1px #ebd391}.course-detail-actions{margin-top:18px;display:flex;justify-content:flex-end;gap:10px}.course-detail-actions button{min-height:42px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;font-size:14px;font-weight:900;text-decoration:none}.course-detail-actions .detail-close-action{color:#344046;background:#eef4f2}.course-detail-actions .detail-source-action{color:#2c4b52;background:#e6f3ef}.course-detail-actions button:not(.detail-close-action):not(.detail-source-action){color:#fff;background:var(--teal)}.course-detail-actions .detail-my-course-action.active{color:#8a4b00;background:#fff4d7;box-shadow:inset 0 0 0 1px #ebd391}.course-detail-actions .detail-my-course-action.active:hover{background:#ffe8ad}.course-detail-actions button:disabled{cursor:default;opacity:.72}@media (max-width: 720px){.course-detail-modal{max-height:calc(100vh - 24px);border-radius:18px}.course-detail-hero{min-height:210px;max-height:260px;padding:10px}.course-detail-image{max-height:240px}.course-detail-list{grid-template-columns:1fr}.course-detail-actions{flex-direction:column}}.login-modal-header{display:flex;justify-content:space-between;gap:16px}.login-modal-header h2{margin:0;color:#1d292e;font-size:22px}.login-modal-header p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.5}.login-modal-header button{width:34px;height:34px;border:0;border-radius:999px;color:#59656a;font-size:24px;line-height:1;background:#f5f8f7}.login-actions{margin-top:20px;display:grid;gap:10px}.social-login{height:48px;padding:0 14px;display:flex;align-items:center;justify-content:center;gap:10px;border:1px solid var(--line);border-radius:12px;color:#20282d;font-weight:850;background:#fff}.social-login span{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;color:#fff;font-size:13px;font-weight:900}.social-login.google span{background:#4285f4}.social-login.naver{color:#0b5f34;background:#f4fff8}.social-login.naver span{background:#03c75a}.login-warning{margin:14px 0 0;padding:10px 12px;border:1px solid #ffd0d0;border-radius:12px;color:#a23d3d;font-size:12px;line-height:1.45;background:#fff6f6}.signup-modal{width:min(460px,100%)}.signup-form{margin-top:18px;display:grid;gap:10px}.signup-form label{display:grid;gap:6px;color:#344046;font-size:13px;font-weight:800}.signup-form input:not([type=checkbox]){height:42px;padding:0 12px;border:1px solid #dce4e1;border-radius:10px;color:var(--text);background:#fff;outline:none}.signup-form input:not([type=checkbox]):focus{border-color:var(--teal);box-shadow:0 0 0 3px #18b7aa1f}.signup-agree{grid-template-columns:18px 1fr;align-items:center;gap:8px;color:#59656a;font-size:12px}.signup-agree input{width:16px;height:16px;accent-color:var(--teal)}.signup-submit{height:46px;border:0;border-radius:12px;color:#fff;font-weight:900;background:var(--teal)}.signup-submit:hover{background:var(--teal-dark)}.signup-social{margin-top:14px}.auth-switch-button{width:100%;margin-top:14px;height:38px;border:0;color:var(--teal-dark);font-weight:850;background:transparent}.rank-badge{position:absolute;top:12px;left:12px;z-index:2;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:3px solid #fff;border-radius:50%;color:#fff;font-weight:900;background:#f7b51d;box-shadow:0 6px 14px #b0770b38}.popular-thumb{position:absolute;top:14px;left:22px;width:64px;height:92px;border-radius:16px}.popular-thumb span{font-size:34px}.popular-copy{min-width:0;padding-right:32px}.popular-copy h3{overflow:hidden;font-size:15px;white-space:nowrap;text-overflow:ellipsis}.popular-copy p{margin:5px 0 0;overflow:hidden;color:#69757b;font-size:12px;white-space:nowrap;text-overflow:ellipsis}.popular-copy .popular-schedule-lines{white-space:normal}.popular-schedule-lines span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.popular-copy strong{display:block;margin-top:7px;color:#1d292e;font-size:15px}.popular-card>.source-chip{position:absolute;right:12px;bottom:12px}@media (max-width: 1280px){.class-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.popular-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.utility-nav span{display:none}.utility-nav .user-session-badge{display:inline-flex}}@media (max-width: 980px){.site-header{overflow-x:hidden}.topbar{width:100%;height:auto;padding:16px 18px;flex-wrap:wrap;gap:14px}.brand{flex:0 1 auto;min-width:224px}.brand-logo{width:218px;height:58px}.search-bar{order:3;min-width:0;max-width:none;flex-basis:100%}.utility-nav{min-width:0;flex:1 1 auto;justify-content:flex-end;overflow:hidden;gap:4px}.utility-nav button{min-width:0;padding:0 8px}.user-session-badge{max-width:96px}.notification-panel{top:84px;right:18px}.layout{grid-template-columns:1fr;padding:18px}.sidebar-shell{position:fixed;left:0;right:0;bottom:0;z-index:75;padding:48px 14px 14px;transform:translateY(104%);border-radius:22px 22px 0 0;background:#fff;box-shadow:0 -18px 48px #1d292e2e;transition:transform .18s ease}.sidebar-shell.open{transform:translateY(0)}.filter-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:block;border:0;background:#151f246b}.mobile-filter-close{position:absolute;top:12px;right:16px;z-index:2;display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 12px;border:1px solid var(--line);border-radius:999px;color:#344046;font-size:13px;font-weight:850;background:#fff}.filter-panel{position:static;max-height:none;overflow:visible;padding:0 4px 12px;border:0;border-radius:0;box-shadow:none}.mobile-filter-bar{position:sticky;top:132px;z-index:10;margin-bottom:12px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:14px;background:#fffffff0;box-shadow:var(--shadow-soft)}.mobile-filter-bar button{min-height:38px;padding:0 16px;border:0;border-radius:10px;color:#fff;font-weight:900;background:var(--teal)}.mobile-filter-bar span{color:#4d5a60;font-size:13px;font-weight:850}.class-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 640px){body{background:var(--bg)}.topbar{gap:10px;padding:12px 14px}.brand{flex:0 0 100%;min-width:auto;max-width:100%;justify-content:center}.brand-logo{width:178px;height:48px}.search-bar{min-height:42px}.utility-nav{order:2;width:100%;flex:0 0 100%;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));justify-content:stretch;gap:4px;font-size:12px}.utility-nav button{width:100%;min-height:34px;padding:0 4px;overflow:hidden;border-radius:9px;white-space:nowrap;text-overflow:ellipsis}.utility-nav b{margin-left:2px;font-size:11px}.user-session-badge{width:34px;min-width:34px;max-width:34px;min-height:34px;padding:0;flex:0 0 34px;border-radius:50%;font-size:12px}.user-session-full{display:none}.user-session-compact{display:inline}.notification-badge{top:0;right:-2px;min-width:15px;height:15px;padding:0 4px;font-size:9px}.notification-panel{inset:auto 10px 10px;top:78px;width:auto;max-height:calc(100vh - 92px);border-radius:16px}.notification-panel-header{padding:14px}.notification-panel-actions{flex-direction:column}.layout{padding:12px}.google-map-card{height:300px;border-radius:18px}.google-map-card>div:first-child{min-height:300px}.map-status-panel{left:10px;right:10px;bottom:10px;max-width:none;font-size:11px}.search-area-button{top:10px;left:10px;height:36px;padding:0 10px;border-radius:10px;font-size:12px}.google-map-approx-button{top:52px}.view-toggle{top:auto;right:14px;bottom:14px}.zoom-control{display:none}.class-grid,.popular-grid{grid-template-columns:1fr}.class-grid.branch-class-grid{display:grid;grid-template-columns:minmax(0,1fr);grid-auto-rows:158px;gap:10px;margin:0 -2px;max-height:170px;padding:2px 8px 10px 2px}.branch-class-grid .class-card{width:100%;height:158px}.branch-course-group{gap:8px;padding:10px;border-radius:16px}.branch-course-group-header{padding:0 0 8px;border-bottom:1px solid #e4ece9}.branch-course-group-title{gap:7px}.branch-course-group.is-expanded .branch-class-grid{grid-template-columns:minmax(0,1fr)}.branch-course-group-header h3{max-width:100%;font-size:15px}.branch-course-group-title strong{padding-inline:8px;font-size:12px}.section-header{align-items:start;flex-direction:column}.section,.popular-section{padding:14px;border-radius:18px}.sort-select{width:100%}.class-card{border-radius:16px}}.layout{max-width:1640px;grid-template-columns:minmax(0,1fr);gap:16px}.sidebar-shell{position:sticky;top:96px;z-index:35;min-width:0}.sidebar{min-width:0}.filter-panel{position:relative;top:auto;padding:8px 12px;display:grid;grid-template-columns:minmax(0,1fr);align-items:center;gap:8px;border-radius:14px}.filter-header{grid-column:1 / -1;margin:0;min-width:0}.filter-header h2{font-size:16px}.filter-header button{min-height:30px;padding:0 8px;border:1px solid var(--line);border-radius:8px;background:#fff}.selected-branch-panel{grid-column:1 / -1;margin:0;grid-template-columns:auto minmax(120px,auto) minmax(0,1fr) auto;align-items:center}.selected-branch-panel button{justify-self:end}.filter-list{grid-column:1 / -1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.active-filter-chips,.detail-filter-panel{margin-top:-2px}.filter-menu-wrap{flex:1 1 144px;min-width:132px;max-width:220px}.detail-filter-panel .filter-menu-wrap{max-width:none}.filter-item{min-height:48px;padding:6px 9px;grid-template-columns:26px minmax(0,1fr) 10px;gap:7px;border:1px solid #e4ece9;border-radius:12px;background:#fff}.filter-item:hover,.filter-item.active{border-color:#18b7aa59;background:#f7fcfa}.filter-icon{width:26px;height:26px;border-radius:8px}.filter-copy{min-width:0;gap:1px}.filter-copy strong,.filter-copy small{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.filter-copy strong{font-size:12px}.filter-copy small{font-size:11px}.filter-chevron{transform:rotate(90deg);font-size:18px}.filter-menu{position:absolute;top:calc(100% + 7px);left:0;z-index:60;width:max-content;min-width:100%;max-width:min(340px,calc(100vw - 40px));max-height:min(420px,calc(100vh - 220px));margin:0;overflow:auto}.date-filter-item{flex:0 1 154px;min-width:144px}@media (min-width: 981px){.filter-panel{position:relative;padding:8px 12px;min-height:48px;grid-template-columns:minmax(0,1fr);gap:8px}.filter-header{align-self:center;display:flex;min-width:0}.filter-list{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;padding-bottom:0;scrollbar-width:none}.filter-list::-webkit-scrollbar{display:none}.filter-menu-wrap{flex:0 0 142px;min-width:142px;max-width:142px}.date-filter-item{flex:0 0 142px;min-width:142px}.filter-toggle-button,.detail-filter-toggle{flex:0 0 132px;width:132px}.filter-item{min-height:42px;padding:5px 8px;grid-template-columns:24px minmax(0,1fr) 8px}.filter-icon{width:24px;height:24px}.filter-copy strong{font-size:11.5px}.filter-copy small{font-size:10.5px}.active-filter-chips{display:none}.detail-filter-panel{position:absolute;top:calc(100% + 6px);right:12px;z-index:80;width:min(720px,calc(100vw - 32px));margin:0;box-shadow:0 18px 42px #1d292e29}.detail-filter-panel .filter-menu-wrap{min-width:0}.selected-branch-panel{display:none}}.age-month-input{padding-left:8px}.mobile-filter-bar,.mobile-filter-close,.filter-scrim{display:none!important}@media (max-width: 980px){.layout{grid-template-columns:minmax(0,1fr);padding:14px}.sidebar-shell{position:sticky;inset:auto;top:132px;z-index:35;padding:0;transform:none;border-radius:0;background:transparent;box-shadow:none;transition:none}.filter-panel{position:relative;max-height:none;overflow:visible;padding:10px;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-soft)}.filter-header{grid-column:1 / -1}.filter-list{grid-column:1 / -1;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.filter-list::-webkit-scrollbar{display:none}.filter-menu-wrap{flex:0 0 148px}.selected-branch-panel{grid-template-columns:1fr auto}.selected-branch-panel span,.selected-branch-panel small{grid-column:1 / -1}}@media (max-width: 640px){.sidebar-shell{top:118px}.filter-panel{gap:8px}.filter-header{display:none}.filter-menu-wrap,.date-filter-item{flex-basis:136px;min-width:136px}.filter-menu{position:fixed;top:178px;left:10px;right:10px;width:auto;max-width:none;max-height:calc(100vh - 198px)}}@media (max-width: 980px){.layout{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;padding:14px}.mobile-filter-bar{position:static;z-index:auto;margin:0;padding:10px 12px;display:flex!important;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow-soft)}.mobile-filter-bar span{min-width:0;overflow:hidden;color:#435158;font-size:13px;font-weight:850;white-space:nowrap;text-overflow:ellipsis}.mobile-filter-bar button{flex:0 0 auto;min-height:38px;padding:0 14px;border:0;border-radius:10px;color:#fff;font-size:13px;font-weight:900;background:var(--teal)}.filter-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;display:block!important;border:0;background:#151f246b}.sidebar-shell{position:fixed;left:0;right:0;bottom:0;top:auto;z-index:75;max-height:86vh;padding:48px 14px 14px;overflow:hidden;transform:translateY(104%);border-radius:22px 22px 0 0;background:#fff;box-shadow:0 -18px 48px #1d292e2e;transition:transform .18s ease}.sidebar-shell.open{transform:translateY(0)}.mobile-filter-close{position:absolute;top:12px;right:16px;z-index:2;min-height:32px;padding:0 13px;display:inline-flex!important;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:999px;color:#344046;font-size:13px;font-weight:850;background:#fff}.filter-panel{height:calc(86vh - 62px);max-height:none;overflow-y:auto;padding:2px 2px 18px;display:block;border:0;border-radius:0;box-shadow:none}.filter-header{margin:0 0 12px;display:flex}.filter-list{display:grid;grid-template-columns:minmax(0,1fr);gap:8px;overflow:visible;padding:0}.active-filter-chips{margin:10px 0}.detail-filter-panel{margin-top:8px;grid-template-columns:minmax(0,1fr);padding:0;border:0;background:transparent}.filter-menu-wrap,.date-filter-item{width:100%;min-width:0;max-width:none;flex:none}.filter-item{min-height:52px;padding:8px 10px;grid-template-columns:28px minmax(0,1fr) 18px}.filter-menu{position:static;width:100%;max-width:none;max-height:260px;margin:6px 0 2px;overflow:auto}.selected-branch-panel{margin:0 0 10px;grid-template-columns:minmax(0,1fr)}.selected-branch-panel button{justify-self:start}}@media (max-width: 640px){.layout{padding:12px}}@media (max-width: 980px){.branch-course-group-header{min-height:68px;grid-template-columns:minmax(0,1fr) auto;gap:7px 8px}.branch-course-group-title{grid-column:1}.branch-course-group-summary{grid-column:1 / -1;flex-wrap:nowrap;overflow:hidden}.branch-course-group-summary span{flex:0 1 auto;max-width:132px}.branch-course-preview{grid-template-columns:minmax(0,1fr)}.branch-course-group-toggle{grid-column:2;grid-row:1}.branch-course-group.is-expanded .branch-class-grid,.class-grid.branch-class-grid{max-height:460px;grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;gap:7px;margin:0;padding:8px}.branch-class-grid .class-card{width:100%;height:auto}.branch-class-grid .class-body{grid-template-columns:minmax(0,1fr) auto;gap:5px 10px}.branch-class-grid .class-title-row,.branch-class-grid .age-text{grid-column:1}.branch-class-grid .class-meta{grid-column:1 / -1;grid-row:auto}.branch-class-grid .class-footer{grid-column:2;grid-row:1 / span 2}}@media (max-width: 640px){.branch-course-group{padding:0;border-radius:8px}.branch-course-group-header{padding:9px 10px}.branch-course-group-header h3{font-size:13.5px}.branch-course-group-title strong{padding-inline:7px;font-size:11.5px}.branch-course-group-summary{gap:4px;font-size:11px}.branch-course-group-summary span{max-width:108px;min-height:21px;padding:3px 6px}.branch-course-preview{padding:0 7px 7px}.branch-course-preview-item{min-height:58px;grid-template-columns:auto minmax(0,1fr)}.branch-course-preview-item em{grid-column:2;grid-row:2;justify-self:end}.branch-course-group.is-expanded .branch-class-grid,.class-grid.branch-class-grid{max-height:430px}.branch-class-grid .class-body{padding:8px 9px}.branch-class-grid .class-title-row h3{font-size:13.5px}.branch-class-grid .age-text,.branch-class-grid .class-meta,.branch-class-grid .class-meta .meta-row-priority dd{font-size:11.5px}.branch-class-grid .class-footer{min-width:82px}.branch-class-grid .class-footer strong{font-size:12px}}.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:520px;display:grid;grid-template-columns:minmax(0,1fr);grid-auto-rows:auto;gap:7px;margin:0;padding:8px;overflow-x:hidden;overflow-y:auto}.branch-course-group.is-expanded .branch-class-grid .class-card{width:100%;height:auto;min-height:0;display:block;border-radius:8px;box-shadow:none}.branch-course-group.is-expanded .branch-class-grid .class-thumb{display:none}.branch-course-group.is-expanded .branch-class-grid .class-body{min-width:0;padding:9px 11px;display:grid;grid-template-columns:minmax(0,1.5fr) minmax(210px,1fr) auto;gap:6px 12px;align-items:center}.branch-course-group.is-expanded .branch-class-grid .class-title-row{grid-column:1;min-width:0}.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{min-height:0;overflow:hidden;display:-webkit-box;font-size:14px;line-height:1.25;letter-spacing:0;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-course-group.is-expanded .branch-class-grid .age-text{grid-column:1;margin:0;padding:0;border-radius:0;background:transparent}.branch-course-group.is-expanded .branch-class-grid .class-meta{grid-column:2;grid-row:1 / span 2;margin:0}.branch-course-group.is-expanded .branch-class-grid .class-meta>div:not(.meta-row-schedule){display:none}.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority{padding:0;border:0;box-shadow:none;background:transparent}.branch-course-group.is-expanded .branch-class-grid .class-footer{grid-column:3;grid-row:1 / span 2;margin:0;min-width:96px;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:5px}@media (max-width: 980px){.branch-course-group.is-expanded .branch-class-grid .class-body{grid-template-columns:minmax(0,1fr) auto}.branch-course-group.is-expanded .branch-class-grid .class-meta{grid-column:1 / -1;grid-row:auto}.branch-course-group.is-expanded .branch-class-grid .class-footer{grid-column:2;grid-row:1 / span 2}}@media (max-width: 640px){.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:430px}.branch-course-group.is-expanded .branch-class-grid .class-body{padding:8px 9px}.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:13.5px}.branch-course-group.is-expanded .branch-class-grid .class-footer{min-width:82px}}.branch-course-preview{grid-template-columns:repeat(2,minmax(0,1fr))}.branch-course-preview-item{min-height:72px;padding:7px 9px;grid-template-columns:50px auto minmax(0,1fr) auto;grid-template-areas:"thumb status title price" "thumb age age price" "thumb schedule schedule price";gap:3px 7px}.branch-course-preview-item span.preview-thumb{grid-area:thumb;width:50px;height:50px;min-width:50px;overflow:hidden;display:flex;align-items:center;justify-content:center;border-radius:7px;color:#253239;font-size:20px;font-weight:900}.branch-course-preview-item .preview-thumb img{width:100%;height:100%;display:block;object-fit:cover}.branch-course-preview-item .preview-status{grid-area:status;align-self:start;min-height:20px;padding:2px 6px;font-size:10px;line-height:1.35;white-space:nowrap}.branch-course-preview-item strong{grid-area:title;align-self:start;min-height:0;display:-webkit-box;overflow:hidden;font-size:13px;line-height:1.25;white-space:normal;word-break:keep-all;overflow-wrap:anywhere;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-course-preview-item .preview-age{grid-area:age}.branch-course-preview-item .preview-schedule{grid-area:schedule}.branch-course-preview-item em{grid-area:price;grid-column:auto;grid-row:auto;align-self:center}.branch-course-group.is-expanded .branch-class-grid .class-card{display:grid;grid-template-columns:104px minmax(0,1fr);min-height:132px;overflow:hidden}.branch-course-group.is-expanded .branch-class-grid .class-thumb{display:flex;height:100%;min-height:132px}.branch-course-group.is-expanded .branch-class-grid .thumb-emoji{font-size:38px}.branch-course-group.is-expanded .branch-class-grid .favorite-button{top:7px;right:7px;width:28px;height:28px;font-size:15px}.branch-course-group.is-expanded .branch-class-grid .status-badge{left:7px;bottom:7px;max-width:44px;padding:3px 6px;overflow:hidden;font-size:10.5px;line-height:1.25;white-space:nowrap;text-overflow:ellipsis}.branch-course-group.is-expanded .branch-class-grid .class-body{min-width:0;min-height:132px;padding:10px 12px;display:grid;grid-template-columns:minmax(0,1fr) minmax(200px,.8fr) minmax(92px,auto);grid-template-areas:"title meta footer" "age meta footer";gap:6px 12px;align-items:start}.branch-course-group.is-expanded .branch-class-grid .class-title-row{grid-area:title;display:block;min-width:0}.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{min-height:0;display:block;overflow:visible;color:#19252b;font-size:14px;line-height:1.35;letter-spacing:0;white-space:normal;word-break:keep-all;overflow-wrap:anywhere;-webkit-line-clamp:initial;-webkit-box-orient:initial}.branch-course-group.is-expanded .branch-class-grid .age-text{grid-area:age;min-width:0;align-self:start}.branch-course-group.is-expanded .branch-class-grid .class-meta{grid-area:meta;align-self:center}.branch-course-group.is-expanded .branch-class-grid .class-footer{grid-area:footer;min-width:92px;align-self:center}@media (max-width: 980px){.branch-course-preview{grid-template-columns:minmax(0,1fr)}.branch-course-group.is-expanded .branch-class-grid .class-body{grid-template-columns:minmax(0,1fr) minmax(86px,auto);grid-template-areas:"title footer" "age footer" "meta meta"}}@media (max-width: 640px){.branch-course-preview-item{grid-template-columns:46px auto minmax(0,1fr);grid-template-areas:"thumb status price" "thumb title title" "thumb age age" "thumb schedule schedule"}.branch-course-preview-item span.preview-thumb{width:46px;height:58px;min-width:46px}.branch-course-preview-item em{justify-self:end;font-size:11.5px}.branch-course-group.is-expanded .branch-class-grid .class-card{grid-template-columns:82px minmax(0,1fr);min-height:126px}.branch-course-group.is-expanded .branch-class-grid .class-thumb{min-height:126px}.branch-course-group.is-expanded .branch-class-grid .class-body{min-height:126px;padding:8px 9px;grid-template-columns:minmax(0,1fr);grid-template-areas:"title" "age" "meta" "footer";gap:5px}.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:13.5px;line-height:1.32}.branch-course-group.is-expanded .branch-class-grid .class-footer{min-width:0;flex-direction:row;align-items:center;justify-content:space-between}}@media (min-width: 981px){.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:560px;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.branch-course-group.is-expanded .branch-class-grid .class-card{grid-template-columns:74px minmax(0,1fr);min-height:124px}.branch-course-group.is-expanded .branch-class-grid .class-thumb{min-height:124px}.branch-course-group.is-expanded .branch-class-grid .class-body{min-height:124px;padding:6px 7px;grid-template-columns:minmax(0,1fr);grid-template-areas:"title" "age" "meta" "footer";gap:1px}.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{display:-webkit-box;overflow:hidden;font-size:13.5px;line-height:1.16;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-course-group.is-expanded .branch-class-grid .thumb-emoji{font-size:28px}.branch-course-group.is-expanded .branch-class-grid .favorite-button{top:5px;right:5px;width:24px;height:24px;font-size:13px}.branch-course-group.is-expanded .branch-class-grid .status-badge{left:5px;bottom:5px;max-width:38px;padding:2px 5px;font-size:9.5px}.branch-course-group.is-expanded .branch-class-grid .age-text{align-self:start;gap:3px;font-size:12px;line-height:1.12}.branch-course-group.is-expanded .branch-class-grid .age-text span{font-size:9.5px}.branch-course-group.is-expanded .branch-class-grid .age-text strong{font-size:12px;line-height:1.12}.branch-course-group.is-expanded .branch-class-grid .class-meta{align-self:start;gap:1px;font-size:12px;line-height:1.12}.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority{gap:2px}.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dt{font-size:9.5px}.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dd{font-size:12px;line-height:1.12}.branch-course-group.is-expanded .branch-class-grid .schedule-line{line-height:1.12}.branch-course-group.is-expanded .branch-class-grid .class-footer{min-width:0;width:100%;flex-direction:row;align-items:center;justify-content:space-between;gap:4px}.branch-course-group.is-expanded .branch-class-grid .class-footer strong{font-size:12.5px;line-height:1.1}.branch-course-group.is-expanded .branch-class-grid .class-footer button{min-height:24px;padding:0 8px;font-size:12px}}.branch-course-group .class-grid.branch-class-grid{max-height:276px;display:grid;grid-auto-rows:auto;gap:6px;margin:0;padding:8px;overflow-x:hidden;overflow-y:auto;scroll-snap-type:y proximity}.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:none;overflow:visible;scroll-snap-type:none}@media (min-width: 981px){.branch-course-group .class-grid.branch-class-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.branch-course-group .branch-class-grid .class-card{width:100%;height:auto;min-height:124px;display:grid;grid-template-columns:74px minmax(0,1fr);overflow:hidden;border-radius:8px;box-shadow:none}.branch-course-group .branch-class-grid .class-thumb{display:flex;height:100%;min-height:124px}.branch-course-group .branch-class-grid .thumb-emoji{font-size:28px}.branch-course-group .branch-class-grid .favorite-button{top:5px;right:5px;width:24px;height:24px;font-size:13px}.branch-course-group .branch-class-grid .status-badge{left:5px;bottom:5px;max-width:38px;padding:2px 5px;overflow:hidden;font-size:9.5px;line-height:1.25;white-space:nowrap;text-overflow:ellipsis}.branch-course-group .branch-class-grid .class-body{min-width:0;min-height:124px;padding:6px 7px;display:grid;grid-template-columns:minmax(0,1fr);grid-template-areas:"title" "age" "meta" "footer";gap:1px;align-items:start}.branch-course-group .branch-class-grid .class-title-row{grid-area:title;display:block;min-width:0}.branch-course-group .branch-class-grid .class-title-row h3{min-height:0;display:-webkit-box;overflow:hidden;color:#19252b;font-size:13.5px;line-height:1.16;letter-spacing:0;white-space:normal;word-break:keep-all;overflow-wrap:anywhere;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-course-group .branch-class-grid .age-text{grid-area:age;min-width:0;align-self:start;gap:3px;font-size:12px;line-height:1.12}.branch-course-group .branch-class-grid .age-text span{font-size:9.5px}.branch-course-group .branch-class-grid .age-text strong{font-size:12px;line-height:1.12}.branch-course-group .branch-class-grid .class-meta{grid-area:meta;align-self:start;gap:1px;font-size:12px;line-height:1.12}.branch-course-group .branch-class-grid .class-meta>div:not(.meta-row-schedule){display:none}.branch-course-group .branch-class-grid .class-meta .meta-row-priority{gap:2px;padding:0;border:0;box-shadow:none;background:transparent}.branch-course-group .branch-class-grid .class-meta .meta-row-priority dt{font-size:9.5px}.branch-course-group .branch-class-grid .class-meta .meta-row-priority dd{font-size:12px;line-height:1.12}.branch-course-group .branch-class-grid .schedule-line{line-height:1.12}.branch-course-group .branch-class-grid .class-footer{grid-area:footer;min-width:0;width:100%;margin:0;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:4px}.branch-course-group .branch-class-grid .class-footer strong{font-size:12.5px;line-height:1.1}.branch-course-group .branch-class-grid .class-footer button{min-height:24px;padding:0 8px;font-size:12px}}@media (max-width: 980px){.branch-course-group .class-grid.branch-class-grid{max-height:360px}.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:none}}.branch-course-groups{gap:14px}.branch-course-group{position:relative;overflow:hidden;border:1px solid #d8e5e0;border-left:5px solid #18b7aa;border-radius:10px;background:#f8fbfa;box-shadow:0 8px 18px #27394012}.branch-course-group:nth-child(3n+2){border-left-color:#f0c737}.branch-course-group:nth-child(3n){border-left-color:#454b52}.branch-course-group.is-expanded{border-color:#bddbd4;background:#f3faf8;box-shadow:0 12px 26px #1f363c1c}.branch-course-group-header{border-bottom:1px solid #dfeae6;background:linear-gradient(180deg,#fff,#f4faf8)}.branch-course-group-header:hover{background:#eef8f5}.branch-course-group.is-expanded .branch-course-group-header{border-bottom-color:#c9ded8;background:#eaf7f4}.branch-course-group .class-grid.branch-class-grid{background:#fbfdfc}.branch-course-group.is-expanded .class-grid.branch-class-grid{background:#f7fbfa}.branch-course-group+.branch-course-group{margin-top:2px}@media (max-width: 640px){.branch-course-groups{gap:12px}.branch-course-group{border-left-width:4px;border-radius:9px}}.branch-course-group .branch-class-grid .age-text{width:100%;max-width:100%;margin:0;padding:4px 6px;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:start;gap:3px}.branch-course-group .branch-class-grid .age-text span{flex:none;white-space:nowrap}.branch-course-group .branch-class-grid .age-text strong{min-width:0;display:-webkit-box;overflow:hidden;white-space:normal;word-break:keep-all;overflow-wrap:anywhere;-webkit-line-clamp:2;-webkit-box-orient:vertical}.branch-course-group .branch-class-grid .class-footer{min-width:0;overflow:hidden}.branch-course-group .branch-class-grid .class-footer strong{flex:0 0 auto;min-width:max-content;white-space:nowrap;letter-spacing:0}.branch-course-group .branch-class-grid .class-footer button{flex:0 0 auto;min-width:42px}@media (min-width: 981px){.branch-course-group .branch-class-grid .class-body{grid-template-rows:auto minmax(28px,auto) auto auto}.branch-course-group .branch-class-grid .age-text strong{max-height:27px}}@media (max-width: 640px){.branch-course-group .branch-class-grid .class-footer strong{font-size:12px}.branch-course-group .branch-class-grid .class-footer button{min-width:38px;padding:0 7px}}@media (min-width: 981px){.branch-course-group .class-grid.branch-class-grid,.branch-course-group.is-expanded .class-grid.branch-class-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 8px}.branch-course-group .branch-class-grid .class-title-row h3,.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:15px;line-height:1.2}.branch-course-group .branch-class-grid .age-text,.branch-course-group.is-expanded .branch-class-grid .age-text{font-size:13px;line-height:1.18}.branch-course-group .branch-class-grid .age-text span,.branch-course-group.is-expanded .branch-class-grid .age-text span,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dt,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dt{font-size:10.5px}.branch-course-group .branch-class-grid .age-text strong,.branch-course-group.is-expanded .branch-class-grid .age-text strong,.branch-course-group .branch-class-grid .class-meta,.branch-course-group.is-expanded .branch-class-grid .class-meta,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dd,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dd{font-size:13px;line-height:1.18}.branch-course-group .branch-class-grid .class-footer strong,.branch-course-group.is-expanded .branch-class-grid .class-footer strong{font-size:14px}.branch-course-group .branch-class-grid .class-footer button,.branch-course-group.is-expanded .branch-class-grid .class-footer button{font-size:13px}}@media (max-width: 640px){.branch-course-group .branch-class-grid .class-title-row h3{font-size:14px}.branch-course-group .branch-class-grid .age-text strong,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dd{font-size:12.5px}}.branch-course-group:not(.is-expanded) .class-grid.branch-class-grid{max-height:none;overflow:visible;scroll-snap-type:none}.branch-course-group-actions{padding:0 8px 9px;display:flex;justify-content:center}.branch-course-expand-button{min-height:30px;padding:0 14px;border:1px solid #cfe1dc;border-radius:999px;color:#24525a;font-size:12.5px;font-weight:900;background:#fff;box-shadow:0 4px 10px #1f363c14}.branch-course-expand-button:hover{border-color:#98c9bd;background:#eef8f5}.branch-subfilter-empty{min-height:92px;padding:18px;display:flex;align-items:center;justify-content:center;grid-column:1 / -1;border:1px dashed #d6e4df;border-radius:10px;color:#6f7d84;font-size:13px;font-weight:850;background:#f8fbfa}.branch-course-group .branch-class-grid .class-body,.branch-course-group.is-expanded .branch-class-grid .class-body{gap:5px}.branch-course-group .branch-class-grid .class-title-row,.branch-course-group.is-expanded .branch-class-grid .class-title-row{padding-bottom:5px;border-bottom:1px solid #edf2ef}.branch-course-group .branch-class-grid .class-title-row h3,.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{color:#152329;font-size:15.5px;font-weight:950;line-height:1.28;letter-spacing:0;word-break:keep-all;overflow-wrap:anywhere}.branch-course-group .branch-class-grid .age-text,.branch-course-group.is-expanded .branch-class-grid .age-text{margin-top:1px;padding:2px 8px 0;display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:6px;border-radius:0;color:#4b5a60;background:transparent;box-shadow:none}.branch-course-group .branch-class-grid .age-text-with-instructor,.branch-course-group.is-expanded .branch-class-grid .age-text-with-instructor{width:100%;grid-template-columns:42px minmax(0,1fr)}.branch-course-group .branch-class-grid .age-text .age-label,.branch-course-group.is-expanded .branch-class-grid .age-text .age-label{color:#7f8c91;font-size:10.5px;font-weight:900;line-height:1.2;text-align:left}.branch-course-group .branch-class-grid .age-text .age-value,.branch-course-group.is-expanded .branch-class-grid .age-text .age-value{min-width:0;display:flex;align-items:baseline;gap:6px;overflow:hidden}.branch-course-group .branch-class-grid .age-text strong,.branch-course-group.is-expanded .branch-class-grid .age-text strong{min-width:0;overflow:hidden;color:#2e3d43;font-size:12.8px;font-weight:850;line-height:1.22;white-space:nowrap;text-overflow:ellipsis}.branch-course-group .branch-class-grid .age-text em,.branch-course-group.is-expanded .branch-class-grid .age-text em{flex:0 1 auto;min-width:0;overflow:hidden;color:#66747a;font-size:12.2px;font-style:normal;font-weight:800;line-height:1.22;text-align:left;white-space:nowrap;text-overflow:ellipsis}.branch-course-group .branch-class-grid .age-text em b,.branch-course-group.is-expanded .branch-class-grid .age-text em b{margin-right:4px;color:#b3bdc1;font-weight:900}.branch-course-group .branch-class-grid .class-footer,.branch-course-group.is-expanded .branch-class-grid .class-footer{margin-top:3px;padding:2px 8px 0;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;border-top:0}.class-price{min-width:0;width:100%;display:grid;grid-template-columns:42px minmax(0,1fr);align-content:center;align-items:center;gap:6px}.class-price small{color:#7f8c91;font-size:10.5px;font-weight:900;line-height:1.2;text-align:left}.class-price strong,.branch-course-group .branch-class-grid .class-footer .class-price strong,.branch-course-group.is-expanded .branch-class-grid .class-footer .class-price strong{min-width:0;max-width:100%;overflow:hidden;color:#2e3d43;font-size:13px;font-weight:900;line-height:1.2;letter-spacing:0;white-space:nowrap;text-overflow:ellipsis}.branch-course-group .branch-class-grid .class-meta .meta-row-priority dt,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dt{color:#7f8c91;font-size:10.5px;font-weight:900;line-height:1.2}.branch-course-group .branch-class-grid .class-meta .meta-row-priority,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority{grid-template-columns:42px minmax(0,1fr)}.branch-course-group .branch-class-grid .class-meta>.meta-row-instructor-primary,.branch-course-group.is-expanded .branch-class-grid .class-meta>.meta-row-instructor-primary{display:grid}.branch-course-group .branch-class-grid .class-meta .meta-row-schedule,.branch-course-group.is-expanded .branch-class-grid .meta-row-schedule,.branch-course-group .branch-class-grid .class-meta .meta-row-instructor-primary,.branch-course-group.is-expanded .branch-class-grid .meta-row-instructor-primary{background:transparent;box-shadow:none;padding:2px 8px 0}.branch-course-group .branch-class-grid .class-meta,.branch-course-group.is-expanded .branch-class-grid .class-meta,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dd,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dd,.branch-course-group .branch-class-grid .schedule-line,.branch-course-group.is-expanded .branch-class-grid .schedule-line{color:#2e3d43;font-size:12.8px;font-weight:850;line-height:1.22}.branch-course-group .branch-class-grid .class-meta-secondary,.branch-course-group.is-expanded .branch-class-grid .class-meta-secondary{margin-top:2px;gap:4px}.branch-course-group .branch-class-grid .class-footer button,.branch-course-group.is-expanded .branch-class-grid .class-footer button{min-width:48px;min-height:28px;padding:0 10px}@media (max-width: 640px){.branch-course-group .branch-class-grid .class-title-row h3,.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:14.5px;line-height:1.3}.branch-course-group .branch-class-grid .age-text,.branch-course-group.is-expanded .branch-class-grid .age-text,.branch-course-group .branch-class-grid .class-meta .meta-row-priority,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority,.class-price,.branch-course-group .branch-class-grid .age-text-with-instructor,.branch-course-group.is-expanded .branch-class-grid .age-text-with-instructor{grid-template-columns:40px minmax(0,1fr)}.class-price strong,.branch-course-group .branch-class-grid .class-footer .class-price strong,.branch-course-group.is-expanded .branch-class-grid .class-footer .class-price strong{font-size:12.8px}.branch-course-group .branch-class-grid .class-footer,.branch-course-group.is-expanded .branch-class-grid .class-footer{grid-template-columns:1fr;gap:6px}.class-price{grid-template-columns:40px minmax(0,1fr)}.class-price strong,.branch-course-group .branch-class-grid .class-footer .class-price strong,.branch-course-group.is-expanded .branch-class-grid .class-footer .class-price strong{overflow:visible;white-space:nowrap;text-overflow:clip}.class-actions{width:100%;justify-content:flex-end;gap:6px}.branch-course-group .branch-class-grid .class-footer button,.branch-course-group.is-expanded .branch-class-grid .class-footer button{min-width:54px;min-height:28px;padding:0 9px;font-size:12px}}.branch-course-group-title-button{min-width:0;padding:0;border:0;display:flex;align-items:center;text-align:left;background:transparent;cursor:pointer}.branch-course-group-title-button:focus-visible,.branch-course-group-toggle:focus-visible{outline:3px solid rgba(24,183,170,.28);outline-offset:3px}.branch-course-quick-filters{min-width:0;display:grid;grid-template-columns:minmax(92px,1fr) minmax(130px,1.15fr) minmax(82px,.85fr) minmax(94px,.9fr);gap:6px;align-items:center}.branch-course-quick-filters label{min-width:0;display:grid;gap:2px}.branch-course-quick-filters span{color:#65757b;font-size:10.5px;font-weight:850;line-height:1}.branch-course-quick-filters select,.branch-course-quick-filters input{width:100%;min-width:0;min-height:30px;padding:0 8px;border:1px solid #d7e5e1;border-radius:7px;color:#1d292e;font:inherit;font-size:12.5px;font-weight:800;background:#fff}.branch-course-quick-filters input{padding-right:4px}.branch-course-quick-filters select:focus,.branch-course-quick-filters input:focus{border-color:#76bfb4;outline:3px solid rgba(24,183,170,.16)}@media (max-width: 980px){.branch-course-group-header{grid-template-columns:minmax(0,1fr)}.branch-course-quick-filters{grid-template-columns:repeat(2,minmax(0,1fr));order:3}.branch-course-group-toggle{justify-self:start}}@media (max-width: 520px){.branch-course-quick-filters{grid-template-columns:minmax(0,1fr)}}@media (max-width: 1280px){.utility-nav .user-session-badge .user-session-full{display:inline}.utility-nav .user-session-badge .user-session-compact{display:none}}@media (max-width: 640px){.utility-nav .user-session-badge .user-session-full{display:none}.utility-nav .user-session-badge .user-session-compact{display:inline}}.branch-course-group{overflow:visible}.branch-course-quick-filters{display:flex;flex-wrap:wrap;gap:5px;align-items:center}.branch-quick-filter{position:relative;min-width:0}.branch-quick-filter-chip{position:relative;max-width:132px;min-height:28px;padding:0 9px;display:inline-flex;align-items:center;overflow:hidden;border:1px dashed #cfded9;border-radius:999px;color:#607078;font-size:12px;font-weight:850;background:#f8fbfa;white-space:nowrap;text-decoration:none;text-overflow:ellipsis}.branch-quick-date-chip{cursor:pointer}.branch-quick-date-chip span{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.branch-quick-date-chip input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.branch-quick-filter-chip:hover,.branch-quick-filter-chip:focus-visible{color:#24525a;border-style:solid;border-color:#9fcfc6;background:#eef8f5;text-decoration:none}.branch-quick-filter-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:30;width:max-content;min-width:128px;max-width:min(260px,72vw);max-height:260px;padding:6px;display:grid;gap:3px;overflow:auto;border:1px solid #d9e7e3;border-radius:10px;background:#fff;box-shadow:0 16px 34px #1f363c2e}.branch-quick-filter-menu button{min-height:30px;padding:0 9px;border:0;border-radius:7px;color:#334349;font-size:12.5px;font-weight:800;text-align:left;background:transparent}.branch-quick-filter-menu button:hover,.branch-quick-filter-menu button.active{color:#123f45;background:#edf8f5}.branch-quick-filter-date{min-width:190px}.branch-quick-filter-date input{min-height:32px;padding:0 8px;border:1px solid #d7e5e1;border-radius:7px;color:#1d292e;font:inherit;font-size:12.5px;font-weight:800}.branch-quick-calendar{width:252px;max-height:none;padding:10px;overflow:visible}.branch-quick-calendar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.branch-quick-calendar-header strong{color:#1d292e;font-size:13.5px;font-weight:900}.branch-quick-filter-menu .branch-quick-calendar-nav{width:28px;min-height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:#496168;font-size:14px;text-align:center;background:#f3f8f6}.branch-quick-calendar-weekdays,.branch-quick-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:3px}.branch-quick-calendar-weekdays{margin-bottom:4px}.branch-quick-calendar-weekdays span{min-width:0;color:#7c8b90;font-size:10.5px;font-weight:900;text-align:center}.branch-quick-filter-menu .branch-quick-calendar-day{width:100%;min-height:30px;padding:0;border-radius:8px;color:#26383f;font-size:12.5px;font-weight:850;text-align:center;background:transparent}.branch-quick-filter-menu .branch-quick-calendar-day.outside{color:#b0bdc1}.branch-quick-filter-menu .branch-quick-calendar-day.today{color:#0d756d;box-shadow:inset 0 0 0 1px #2ec4b6}.branch-quick-filter-menu .branch-quick-calendar-day.selected{color:#fff;background:#18a999;box-shadow:none}.branch-quick-calendar-footer{display:flex;justify-content:space-between;gap:6px;margin-top:8px}.branch-quick-filter-menu .branch-quick-calendar-footer button{flex:1;min-height:30px;padding:0 8px;text-align:center;background:#f3f8f6}@media (max-width: 980px){.branch-course-quick-filters{order:3}}.main-quick-filter-list{gap:5px;align-items:center}.main-quick-filter{flex:0 0 104px;min-width:104px}.main-quick-filter-chip{width:100%;max-width:none;min-height:29px;padding:2px 8px;display:grid;align-content:center;gap:0;border-style:dashed;text-align:left;text-decoration:none}.main-quick-filter-chip span,.main-quick-filter-chip small{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.main-quick-filter-chip span{color:#334349;font-size:10.5px;font-weight:900}.main-quick-filter-chip small{color:#78878d;font-size:9.5px;font-weight:850}.main-quick-filter-chip.active,.main-quick-filter-chip:hover,.main-quick-filter-chip:focus-visible{border-style:solid;border-color:#9fcfc6;background:#eef8f5}.main-quick-filter-menu{min-width:186px;max-width:min(340px,84vw);max-height:min(390px,calc(100vh - 210px))}.main-quick-filter-check{min-height:30px;padding:0 8px;display:flex;align-items:center;gap:8px;border-radius:7px;color:#334349;font-size:12.5px;font-weight:800}.main-quick-filter-check:hover{background:#edf8f5}.main-quick-filter-check input{width:15px;height:15px;flex:0 0 auto;accent-color:var(--teal)}.main-quick-filter-check span{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.main-quick-filter .age-month-input{min-height:auto;margin-top:5px;padding:8px 6px 0;border-top:1px solid rgba(226,232,228,.9)}.main-quick-calendar{min-width:252px}.filter-header{gap:8px}@media (min-width: 981px){.main-quick-filter-list{flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;scrollbar-width:none}.main-quick-filter-list::-webkit-scrollbar{display:none}}@media (max-width: 980px){.main-quick-filter-list{display:flex!important;grid-template-columns:none;flex-wrap:nowrap;align-items:stretch;gap:6px;min-width:0;overflow-x:auto;overflow-y:visible;padding-bottom:4px;scrollbar-width:none}.main-quick-filter-list::-webkit-scrollbar{display:none}.main-quick-filter,.main-quick-filter-list .detail-filter-toggle{width:104px;min-width:104px;max-width:104px;flex:0 0 104px}.main-quick-filter-chip{min-height:32px;padding:3px 8px}.main-quick-filter-chip span{font-size:10px}.main-quick-filter-chip small{font-size:9px}.main-quick-filter-menu,.branch-quick-calendar.main-quick-calendar{position:fixed;top:126px;left:12px;right:12px;z-index:95;width:auto;min-width:0;max-width:none;max-height:min(62vh,420px);overflow:auto}.main-quick-calendar{min-width:0}.active-filter-chips{display:none}}@media (max-width: 520px){.main-quick-filter,.main-quick-filter-list .detail-filter-toggle{width:96px;min-width:96px;max-width:96px;flex-basis:96px}.main-quick-filter-menu,.branch-quick-calendar.main-quick-calendar{top:112px}}@media (max-width: 640px){.course-compare-table-wrap-mobile{overflow:visible;border:0;background:transparent}.course-compare-table-transposed{width:100%;min-width:0!important;display:block;table-layout:auto;border-collapse:separate}.course-compare-table-transposed thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.course-compare-table-transposed tbody{display:grid;gap:10px}.course-compare-table-transposed tr{width:100%;display:grid;overflow:hidden;border:1px solid #e3ece8;border-radius:10px;background:#fff}.course-compare-table-transposed th,.course-compare-table-transposed td{width:auto!important;padding:8px 10px;border-right:0;border-bottom:1px solid #edf3f0;font-size:12px}.course-compare-table-transposed tbody th:first-child{position:static!important;left:auto!important;z-index:auto;display:block;background:#f8fbfa}.course-compare-table-transposed .compare-title-button{width:100%}.course-compare-table-transposed .compare-title-button span{font-size:13px;line-height:1.28;-webkit-line-clamp:2;overflow-wrap:anywhere}.course-compare-table-transposed td{display:grid;grid-template-columns:70px minmax(0,1fr);gap:8px;align-items:start;color:#26363c}.course-compare-table-transposed td:before{color:#728087;font-size:11px;font-weight:950;white-space:nowrap}.course-compare-table-transposed td:nth-child(2):before{content:"문화센터"}.course-compare-table-transposed td:nth-child(3):before{content:"지점"}.course-compare-table-transposed td:nth-child(4):before{content:"대상"}.course-compare-table-transposed td:nth-child(5):before{content:"일정"}.course-compare-table-transposed td:nth-child(6):before{content:"강사"}.course-compare-table-transposed td:nth-child(7):before{content:"수강료"}.course-compare-table-transposed td:nth-child(8):before{content:"재료비"}.course-compare-table-transposed td:nth-child(9):before{content:"횟수"}.course-compare-table-transposed td:nth-child(10):before{content:"상태"}.course-compare-table-transposed td:nth-child(11):before{content:"카테고리"}.course-compare-table-transposed td:last-child{display:flex;justify-content:flex-end;border-bottom:0}.course-compare-table-transposed td:last-child:before{content:none}.course-compare-table-transposed .compare-remove-button{margin-top:0}}@media (max-width: 640px){html,body,.app{width:100%;max-width:100%;overflow-x:hidden}.site-header{z-index:55}.topbar{min-width:0;padding:8px 10px 9px;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:7px 8px}.brand{grid-column:1;grid-row:1;min-width:0;max-width:132px;justify-content:flex-start}.brand-button{min-height:36px}.brand-logo{width:128px;height:36px;object-position:left center}.utility-nav{grid-column:2;grid-row:1;width:auto;min-width:0;max-width:100%;display:flex;flex:1 1 auto;justify-content:flex-end;gap:3px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.utility-nav::-webkit-scrollbar{display:none}.utility-nav button{width:auto;min-width:32px;min-height:32px;flex:0 0 auto;padding:0 7px;border-radius:9px;font-size:11.5px}.utility-nav b{margin-left:1px;font-size:10.5px}.user-session-badge{width:32px;min-width:32px;max-width:32px;min-height:32px;flex-basis:32px}.search-bar{grid-column:1 / -1;grid-row:2;min-height:38px}.search-bar input{height:38px;padding:0 44px 0 14px;font-size:14px}.search-bar button{right:3px;width:34px;height:34px;font-size:18px}.layout{gap:9px;padding:9px}.map-tabs{width:100%;margin-bottom:6px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.map-tabs button{min-width:0;min-height:32px;padding:0 8px;font-size:12.5px}.mobile-filter-bar{min-height:38px;padding:6px 8px;border-radius:10px;box-shadow:0 5px 14px #23303712}.mobile-filter-bar span{font-size:12.5px}.mobile-filter-bar button{min-height:32px;padding:0 10px;border-radius:8px;font-size:12.5px}.sidebar-shell{max-height:min(84dvh,680px);padding:42px 12px calc(12px + env(safe-area-inset-bottom));border-radius:18px 18px 0 0}.mobile-filter-close{top:9px;right:12px;min-height:30px}.filter-panel{height:calc(84dvh - 56px);max-height:624px;padding-bottom:calc(16px + env(safe-area-inset-bottom))}.main-quick-filter,.main-quick-filter-list .detail-filter-toggle{width:102px;min-width:102px;max-width:102px;flex-basis:102px}.main-quick-filter-chip{min-height:38px;padding:4px 8px}.main-quick-filter-chip span{font-size:10.5px}.main-quick-filter-chip small{font-size:9.5px}.main-quick-filter-menu,.branch-quick-calendar.main-quick-calendar{top:118px;left:10px;right:10px;max-height:min(58dvh,390px)}.google-map-card{height:clamp(220px,36dvh,300px);border-radius:14px}.google-map-card>div:first-child{min-height:clamp(220px,36dvh,300px)}.map-category-legend{left:8px;top:8px;max-width:calc(100% - 16px);padding:6px;gap:4px}.map-category-legend span{font-size:10px}.map-inline-error{left:8px;right:8px;bottom:8px;max-width:none;font-size:11px}.section.results-section{padding:10px;border-radius:14px}.section-header{gap:8px}.section-header h2{font-size:18px;line-height:1.25}.result-progress,.section-subtitle{font-size:12px}.sort-select{min-height:34px;padding:0 10px;font-size:12.5px}.branch-course-groups{gap:10px}.branch-course-group{border-left-width:4px;border-radius:10px}.branch-course-group-header{min-height:0;padding:8px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:7px}.branch-course-group-title-button{align-items:center;gap:5px}.branch-course-group-header h3{min-width:0;max-width:100%;overflow:hidden;font-size:14px;line-height:1.2;white-space:nowrap;text-overflow:ellipsis}.branch-course-group-title .provider-badge{max-width:72px;padding-inline:6px;overflow:hidden;font-size:10px;white-space:nowrap;text-overflow:ellipsis}.branch-course-group-title strong{flex:0 0 auto;padding-inline:6px;font-size:10.5px}.branch-course-group-toggle{min-height:28px;padding:0 9px;border-radius:999px;font-size:11.5px}.branch-course-quick-filters{grid-column:1 / -1;order:3;display:flex;flex-wrap:nowrap;gap:5px;overflow-x:auto;overflow-y:visible;padding-bottom:1px;scrollbar-width:none}.branch-course-quick-filters::-webkit-scrollbar{display:none}.branch-course-quick-filters .branch-quick-filter{flex:0 0 auto}.branch-course-quick-filters .branch-quick-filter-chip{max-width:112px;min-height:28px;padding:0 8px;font-size:11.5px}.branch-quick-filter-menu{max-width:min(260px,calc(100vw - 28px));max-height:250px}.branch-course-group .class-grid.branch-class-grid{grid-template-columns:minmax(0,1fr);gap:7px;padding:7px}.branch-course-group:not(.is-expanded) .class-grid.branch-class-grid{max-height:184px;overflow-y:auto;overscroll-behavior:contain}.branch-course-group.is-expanded .class-grid.branch-class-grid{max-height:none;overflow:visible}.branch-course-group .branch-class-grid .class-card,.branch-course-group.is-expanded .branch-class-grid .class-card{min-height:150px;height:auto;display:grid;grid-template-columns:84px minmax(0,1fr);border-radius:9px}.branch-course-group .branch-class-grid .class-thumb,.branch-course-group.is-expanded .branch-class-grid .class-thumb{min-height:150px;height:100%}.branch-course-group .branch-class-grid .course-image,.branch-course-group.is-expanded .branch-class-grid .course-image{width:100%;height:100%;object-fit:cover}.branch-course-group .branch-class-grid .favorite-button,.branch-course-group.is-expanded .branch-class-grid .favorite-button{top:5px;right:5px;width:27px;height:27px;font-size:13px}.branch-course-group .branch-class-grid .status-badge,.branch-course-group.is-expanded .branch-class-grid .status-badge{left:5px;bottom:5px;max-width:46px;padding:2px 5px;font-size:10px;line-height:1.2}.branch-course-group .branch-class-grid .class-body,.branch-course-group.is-expanded .branch-class-grid .class-body{min-height:150px;padding:7px;gap:4px}.branch-course-group .branch-class-grid .class-title-row,.branch-course-group.is-expanded .branch-class-grid .class-title-row{padding-bottom:4px}.branch-course-group .branch-class-grid .class-title-row h3,.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:14px;line-height:1.28;-webkit-line-clamp:2}.branch-course-group .branch-class-grid .age-text,.branch-course-group.is-expanded .branch-class-grid .age-text,.branch-course-group .branch-class-grid .class-meta .meta-row-priority,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority,.class-price{grid-template-columns:38px minmax(0,1fr);gap:5px}.branch-course-group .branch-class-grid .age-text,.branch-course-group.is-expanded .branch-class-grid .age-text,.branch-course-group .branch-class-grid .class-meta .meta-row-schedule,.branch-course-group.is-expanded .branch-class-grid .meta-row-schedule,.branch-course-group .branch-class-grid .class-meta .meta-row-instructor-primary,.branch-course-group.is-expanded .branch-class-grid .meta-row-instructor-primary,.branch-course-group .branch-class-grid .class-footer,.branch-course-group.is-expanded .branch-class-grid .class-footer{padding-inline:0}.branch-course-group .branch-class-grid .age-text .age-label,.branch-course-group.is-expanded .branch-class-grid .age-text .age-label,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dt,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dt,.class-price small{font-size:10px}.branch-course-group .branch-class-grid .age-text strong,.branch-course-group.is-expanded .branch-class-grid .age-text strong,.branch-course-group .branch-class-grid .class-meta,.branch-course-group.is-expanded .branch-class-grid .class-meta,.branch-course-group .branch-class-grid .class-meta .meta-row-priority dd,.branch-course-group.is-expanded .branch-class-grid .class-meta .meta-row-priority dd,.branch-course-group .branch-class-grid .schedule-line,.branch-course-group.is-expanded .branch-class-grid .schedule-line{font-size:12.4px;line-height:1.18}.branch-course-group .branch-class-grid .class-footer,.branch-course-group.is-expanded .branch-class-grid .class-footer{grid-template-columns:minmax(0,1fr) auto;gap:5px}.class-price strong,.branch-course-group .branch-class-grid .class-footer .class-price strong,.branch-course-group.is-expanded .branch-class-grid .class-footer .class-price strong{overflow:hidden;font-size:12.4px;white-space:nowrap;text-overflow:ellipsis}.class-actions{width:auto;flex:0 0 auto;justify-content:flex-end;gap:4px}.branch-course-group .branch-class-grid .class-footer button,.branch-course-group.is-expanded .branch-class-grid .class-footer button{min-width:42px;min-height:28px;padding:0 7px;font-size:11.5px}.branch-course-group-actions{padding:0 7px 8px}.branch-course-expand-button{width:100%;min-height:32px;font-size:12.5px}.popular-section{display:none}.modal-backdrop{padding:0;place-items:end stretch}.login-modal,.signup-modal{width:100%;max-height:92dvh;overflow-y:auto;border-radius:18px 18px 0 0}.course-detail-backdrop{align-items:end}.course-detail-modal{width:100%;max-height:94dvh;border-radius:18px 18px 0 0}.modal-close-button{top:10px;right:10px;width:36px;height:36px;font-size:22px}.course-detail-hero{min-height:160px;max-height:210px;padding:8px}.course-detail-image{max-height:194px;border-radius:10px}.course-detail-content{padding:14px 14px 0}.course-detail-title-row{gap:10px}.course-detail-title-row h2{font-size:20px;line-height:1.3;letter-spacing:0}.course-detail-list{margin-top:12px;gap:7px}.course-detail-list div{padding:9px 10px;border-radius:10px}.course-detail-list dd{font-size:13px}.course-detail-description,.course-detail-ai{margin-top:10px;padding:12px}.course-detail-actions{position:sticky;bottom:0;z-index:3;margin:14px -14px 0;padding:10px 14px calc(10px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;background:#fffffff5;border-top:1px solid #edf2ef;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.course-detail-actions button{min-height:40px;padding:0 10px;font-size:13px}.course-detail-actions .detail-close-action{grid-column:1 / -1;order:3}.course-detail-actions .detail-source-action{grid-column:auto}.course-compare-panel{padding:9px;border-radius:12px}.course-compare-header{gap:8px}.course-compare-header h3{font-size:15px}.course-compare-header button,.compare-remove-button{min-height:28px;padding:0 9px;font-size:11.5px}}.layout{display:grid;grid-template-columns:minmax(0,1fr)}.main-content{display:contents}.map-tabs{order:1}.map-card{order:2}.mobile-filter-bar{order:3}.sidebar-shell{order:4}.section.results-section{order:5}.popular-section{order:6}@media (max-width: 640px){.mobile-filter-bar{min-width:0;display:grid!important;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.mobile-filter-bar span{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.mobile-filter-bar button{min-width:max-content;white-space:nowrap}.filter-panel{overflow-x:hidden}.main-quick-filter-list{width:100%;min-width:0;display:flex!important;flex-flow:row nowrap!important;align-items:stretch;gap:6px;overflow-x:auto;overflow-y:visible;padding:0 2px 6px;scrollbar-width:none}.main-quick-filter-list::-webkit-scrollbar{display:none}.main-quick-filter,.main-quick-filter-list .detail-filter-toggle{width:94px;min-width:94px;max-width:94px;flex:0 0 94px}.main-quick-filter-chip{min-height:34px;padding:3px 7px}.branch-course-group:not(.is-expanded) .class-grid.branch-class-grid{max-height:428px;overflow-y:auto;overscroll-behavior:contain}.branch-course-group .branch-class-grid .class-card,.branch-course-group.is-expanded .branch-class-grid .class-card{min-height:132px;grid-template-columns:76px minmax(0,1fr)}.branch-course-group .branch-class-grid .class-thumb,.branch-course-group.is-expanded .branch-class-grid .class-thumb{min-height:132px}.branch-course-group .branch-class-grid .class-body,.branch-course-group.is-expanded .branch-class-grid .class-body{min-height:132px;padding:7px;gap:3px}.branch-course-group .branch-class-grid .class-title-row h3,.branch-course-group.is-expanded .branch-class-grid .class-title-row h3{font-size:14px;line-height:1.24}.branch-course-group .branch-class-grid .class-footer,.branch-course-group.is-expanded .branch-class-grid .class-footer{gap:5px}}
