*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#2d6a4f;--green-light:#40916c;--green-pale:#d8f3dc;--green-bg:#f0faf3;--text:#1b2e1f;--text-2:#4a6355;--text-3:#7a9e8a;--border:#c8e6d0;--card-bg:#fff;--bg:#f5faf6;--radius:14px;--radius-sm:8px;--shadow:0 2px 12px #2d6a4f1a;--shadow-card:0 4px 20px #2d6a4f1f}html,body{background:var(--bg);min-height:100%}#root{background:var(--bg);min-height:100%;color:var(--text);-webkit-font-smoothing:antialiased;flex-direction:column;max-width:480px;min-height:100%;margin:0 auto;font-family:-apple-system,Pretendard,Noto Sans KR,sans-serif;font-size:16px;display:flex}button{cursor:pointer;font:inherit;background:0 0;border:none}img{display:block}.region-screen{flex-direction:column;flex:1;padding:0 0 32px;display:flex}.region-header{text-align:center;padding:48px 24px 32px}.region-logo{margin-bottom:12px;font-size:48px}.region-header h1{color:var(--text);letter-spacing:-.5px;margin-bottom:8px;font-size:24px;font-weight:700}.region-header p{color:var(--text-3);font-size:14px}.region-grid{grid-template-columns:repeat(3,1fr);gap:10px;padding:0 16px;display:grid}.region-chip{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:6px;padding:16px 8px;transition:all .15s;display:flex}.region-chip:active{background:var(--green-pale);border-color:var(--green-light);transform:scale(.97)}.region-emoji{font-size:28px}.region-name{color:var(--text);font-size:13px;font-weight:600}.ad-placeholder{color:#4a6355;letter-spacing:.08em;background:repeating-linear-gradient(45deg,#e8f5e9,#e8f5e9 8px,#c8e6c9 8px 16px);flex-shrink:0;justify-content:center;align-items:center;width:100%;height:64px;font-size:11px;font-weight:700;display:flex}.ad-banner-container{flex-shrink:0;width:100%}.course-list-screen{flex-direction:column;flex:1;min-height:0;display:flex}.course-list-header{background:var(--bg);z-index:10;border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:16px 16px 12px;display:flex;position:sticky;top:0}.back-btn{width:36px;height:36px;color:var(--green);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex}.back-btn:active{background:var(--green-pale)}.course-list-header-text{align-items:baseline;gap:8px;display:flex}.course-list-header-text h2{color:var(--text);font-size:18px;font-weight:700}.course-count{color:var(--text-3);font-size:13px}.course-list-body{flex:1;padding:16px;overflow-y:auto}.course-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.course-card-wrap{position:relative}.course-card{background:var(--card-bg);border-radius:var(--radius);width:100%;box-shadow:var(--shadow);text-align:left;-webkit-tap-highlight-color:transparent;flex-direction:column;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden}.course-card:active{box-shadow:none;transform:scale(.97)}.fav-btn{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;-webkit-tap-highlight-color:transparent;z-index:1;background:#ffffffd9;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:15px;display:flex;position:absolute;top:6px;right:6px}.fav-btn--on{background:#fffffff2}.course-card-img{aspect-ratio:4/3;background:var(--green-pale);width:100%;overflow:hidden}.course-card-img img{object-fit:cover;width:100%;height:100%}.course-card-img-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:32px;display:flex}.spinner-sm{border:2px solid var(--border);border-top-color:var(--green);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}.course-card-body{padding:10px 10px 12px}.course-card-title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.course-card-addr{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:4px;font-size:11px;overflow:hidden}.course-grid-ad{border-radius:var(--radius-sm);grid-column:1/-1;overflow:hidden}.load-more-btn{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;color:var(--green);margin-top:16px;padding:14px;font-size:14px;font-weight:600;display:block}.load-more-btn:disabled{opacity:.5}.loading-state,.empty-state{color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 0;font-size:14px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.course-detail-screen{flex-direction:column;flex:1;display:flex;overflow-y:auto}.detail-hero{aspect-ratio:16/9;background:var(--green-pale);flex-shrink:0;width:100%;position:relative;overflow:hidden}.detail-hero img{object-fit:cover;width:100%;height:100%}.detail-hero-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:56px;display:flex}.detail-hero-gradient{background:linear-gradient(#0000004d 0%,#0000 40% 60%,#0003 100%);position:absolute;inset:0}.detail-back-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:38px;height:38px;color:var(--text);z-index:2;background:#ffffffe6;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;left:16px;box-shadow:0 2px 8px #0003}.detail-fav-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2;cursor:pointer;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:18px;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 2px 8px #0003}.detail-body{padding:20px 20px 40px}.detail-title{color:var(--text);letter-spacing:-.3px;font-size:20px;font-weight:700;line-height:1.4}.detail-overview{color:var(--text-2);margin-top:10px;font-size:14px;line-height:1.6}.detail-divider{background:var(--border);height:1px;margin:20px 0}.spots-heading{color:var(--text);align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.spots-count{color:var(--text-3);font-size:13px;font-weight:500}.spots-list{flex-direction:column;gap:0;display:flex}.spot-card{gap:14px;padding:16px 0;display:flex;position:relative}.spot-card:not(:last-child):after{content:"";background:var(--green-pale);width:2px;position:absolute;top:40px;bottom:-16px;left:17px}.spot-index{background:var(--green);color:#fff;z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex;position:relative}.spot-content{flex:1;padding-top:6px}.spot-name{color:var(--text);font-size:15px;font-weight:600;line-height:1.3}.spot-desc{color:var(--text-2);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:6px;font-size:13px;line-height:1.55;display:-webkit-box;overflow:hidden}.spot-img{aspect-ratio:16/9;object-fit:cover;border-radius:var(--radius-sm);width:100%;margin-top:10px}.naver-links-section{border-top:1px solid var(--border);margin-top:28px;padding-top:20px}.naver-links-label{color:var(--text-3);margin-bottom:10px;font-size:13px}.naver-links-row{gap:8px;display:flex}.naver-btn{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:5px;padding:11px 6px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s;display:flex}.naver-btn:active{background:var(--green-pale);border-color:var(--green-light)}.naver-btn-icon{font-size:16px}.loading-state,.empty-state{color:var(--text-3);flex-direction:column;align-items:center;gap:12px;padding:32px 0;font-size:14px;display:flex}.spinner{border:3px solid var(--green-pale);border-top-color:var(--green);border-radius:50%;width:28px;height:28px;animation:.7s linear infinite spin}.modal-overlay{z-index:100;background:#00000080;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--card-bg);border-radius:20px 20px 0 0;flex-direction:column;align-items:center;gap:12px;width:100%;max-width:480px;margin:0 auto;padding:32px 24px 40px;display:flex}.modal-icon{font-size:40px}.modal-title{color:var(--text);font-size:18px;font-weight:700}.modal-desc{color:var(--text-2);text-align:center;font-size:14px;line-height:1.6}.modal-btn-primary{background:var(--green);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;width:100%;margin-top:8px;padding:15px;font-size:15px;font-weight:700}.modal-btn-primary:disabled{opacity:.6}.modal-btn-cancel{width:100%;color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:12px;font-size:14px}.favorites-screen{flex-direction:column;flex:1;padding-bottom:80px;display:flex;overflow-y:auto}.favorites-header{justify-content:space-between;align-items:center;padding:20px 20px 12px;display:flex}.favorites-header h2{color:var(--text);font-size:18px;font-weight:700}.favorites-count{color:var(--text-3);font-size:13px}.favorites-empty{color:var(--text-3);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:60px 0;font-size:14px;display:flex}.favorites-empty p:first-child{font-size:40px}.fav-grid{grid-template-columns:1fr 1fr;gap:12px;padding:0 16px;display:grid}.fav-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);position:relative;overflow:hidden}.fav-card-main{text-align:left;cursor:pointer;background:0 0;border:none;flex-direction:column;width:100%;padding:0 0 10px;display:flex}.fav-card-img{aspect-ratio:4/3;background:var(--green-pale);width:100%;overflow:hidden}.fav-card-img img{object-fit:cover;width:100%;height:100%}.fav-card-img-placeholder{justify-content:center;align-items:center;width:100%;height:100%;font-size:28px;display:flex}.fav-card-title{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;padding:8px 10px 0;font-size:12px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.fav-card-remove{color:#fff;cursor:pointer;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;display:flex;position:absolute;top:6px;right:6px}.add-slot-btn{background:var(--card-bg);border:1.5px dashed var(--green-light);border-radius:var(--radius);color:var(--green);cursor:pointer;width:calc(100% - 32px);margin:20px 16px 0;padding:13px;font-size:13px;font-weight:600}.app-content{flex-direction:column;flex:1;padding-bottom:96px;display:flex;overflow-y:auto}.tab-bar{-webkit-backdrop-filter:blur(16px);z-index:50;background:#ffffffbf;border:1px solid #c8e6d099;border-radius:50px;gap:4px;padding:4px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #2d6a4f26}.tab-btn{color:var(--text-3);cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;background:0 0;border:none;border-radius:50px;flex-direction:row;align-items:center;gap:6px;padding:10px 20px;font-size:13px;font-weight:600;transition:background .2s,color .2s;display:flex}.tab-btn.active{background:var(--green);color:#fff}.tab-icon{font-size:16px}
