:root{--bg: #F6FFFB;--card: #FFFFFF;--text: #0B1F16;--muted: rgba(11,31,22,.58);--line: rgba(11,31,22,.1);--primary: #A6EBCC;--primary-strong: #44C690;--primary-soft: rgba(166,235,204,.35);--shadow: 0 18px 44px rgba(11,31,22,.08);--radius: 22px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Noto Sans KR,Noto Sans,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:radial-gradient(1000px 600px at 20% 10%,rgba(166,235,204,.4),transparent 60%),radial-gradient(900px 500px at 80% 20%,rgba(68,198,144,.1),transparent 55%),var(--bg)}a{color:inherit;text-decoration:none}button{font-family:inherit}.app{min-height:100%;display:flex;flex-direction:column}main{flex:1;min-height:0;padding:32px 32px 26px;display:flex;flex-direction:column}.shell{width:min(1280px,100%);margin:0 auto;flex:1;display:flex;flex-direction:column;gap:18px;min-height:0}.contentGrid{flex:1;display:grid;grid-template-rows:minmax(168px,10%) 1fr;gap:18px;min-height:0}.bottomGrid{display:grid;grid-template-columns:minmax(0,1.78fr) minmax(0,1fr);gap:18px;min-height:0}.bottomGrid>*{min-width:0}.homeContent{background:#ffffffd1;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.homeContentInner{padding:22px 24px 24px}.homeContentHeader{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.homeContentHeader h2{margin:0;font-size:14px;letter-spacing:-.2px;color:#0b1f16e0}.homeContentLead{margin:0 0 14px;font-size:13px;line-height:1.6;color:#0b1f16b8}.btnLink{font-size:13px;color:#0b1f16d1;text-decoration:none;padding:8px 10px;border-radius:10px;border:1px solid rgba(11,31,22,.1);background:#ffffffb3}.btnLink:hover{background:#fffffff2}.listGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.listCard{display:block;padding:14px 14px 12px;border-radius:16px;border:1px solid rgba(11,31,22,.1);background:#ffffffdb;box-shadow:0 10px 24px #11221a0f;text-decoration:none}.listCard:hover{background:#fffffffa;transform:translateY(-1px)}.listTitle{font-weight:700;font-size:13px;color:#0b1f16eb;letter-spacing:-.2px;margin-bottom:6px}.listDesc{font-size:12.5px;line-height:1.55;color:#0b1f16b3;margin-bottom:10px}.listMeta{font-size:12px;color:#0b1f169e}.doc{background:#ffffffe0;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.docHeader{padding:22px 24px 16px;border-bottom:1px solid rgba(11,31,22,.08)}.docHeader h1{margin:0 0 8px;font-size:18px;letter-spacing:-.4px;color:#0b1f16eb}.docLead{margin:0;font-size:13px;line-height:1.65;color:#0b1f16b8}.docBody{padding:18px 24px 26px;font-size:13.5px;line-height:1.8;color:#0b1f16cc}.docBody h2{margin:16px 0 8px;font-size:14px;color:#0b1f16e6;letter-spacing:-.2px}.docBody h3{margin:0 0 6px;font-size:13.5px;color:#0b1f16eb}.docBody ul,.docBody ol{margin:8px 0 10px 18px}.docNav{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}.docGrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:10px}.docCard{border:1px solid rgba(11,31,22,.1);background:#ffffffdb;border-radius:16px;padding:14px;box-shadow:0 10px 24px #11221a0f}.placeTitleRow{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.titleLink{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;padding:0;font:inherit;font-weight:700;color:#0b1f16eb;cursor:pointer;text-align:left}.titleLink:hover{text-decoration:underline}.miniLink{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(11,31,22,.1);background:#ffffffb3;padding:6px 10px;border-radius:999px;font-size:12px;color:#0b1f16b8;cursor:pointer}.miniLink:hover{background:#fffffff2}header{height:72px;display:flex;align-items:center;padding:0 24px;background:#ffffffbd;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.brand{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.brand h1{margin:0;font-size:20px;letter-spacing:-.4px}.brand .sub{display:none}.panel{background:#fffc;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);min-height:0;overflow:hidden}.topBar{background:#ffffffd1;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 24px;overflow:visible;display:flex;flex-direction:column;min-height:0}.topBarHeader{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.topBarTitle{display:flex;flex-direction:column;gap:6px}.topBarHeader h2{margin:0;font-size:14px;color:#0b1f16e0;letter-spacing:-.3px;display:flex;align-items:center;gap:8px}.topBarEmoji{font-size:16px}.topBarSub{display:none}.topList{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;overflow:visible}.pill{width:100%;display:flex;gap:12px;align-items:center;padding:16px;border-radius:18px;border:1px solid rgba(11,31,22,.1);background:#ffffffc7;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,background .12s ease,border-color .12s ease;box-shadow:0 10px 24px #0b1f160f;color:inherit;font-family:inherit;font-size:14px;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.pill:hover{transform:translateY(-1px);background:#a6ebcc24;border-color:#44c6904d;box-shadow:0 16px 36px #0b1f161a}.pill:active{transform:translateY(0);box-shadow:0 10px 24px #0b1f160f}.rankCard{position:relative}.rankBadge{width:52px;height:52px;border-radius:16px;display:flex;align-items:center;justify-content:center;line-height:1;border:1px solid rgba(11,31,22,.1);background:linear-gradient(180deg,#fffffff2,#ffffffb3);box-shadow:0 6px 16px #0b1f1614;flex:0 0 auto}.rankNumRow{display:flex;align-items:flex-end;gap:2px}.rankNum{font-weight:950;font-size:20px;letter-spacing:-.6px}.rankUnit{font-weight:900;font-size:12px;color:#0b1f16b3;margin-bottom:2px}.topList .pill .title{display:flex;flex-direction:column;line-height:1.15;text-align:left;min-width:0;width:100%}.pill .title b{font-size:14px;letter-spacing:-.3px;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.titleRow{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.scorePill{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 10px;border-radius:999px;font-size:12px;font-weight:950;letter-spacing:-.2px;color:#0b1f16d1;border:1px solid rgba(11,31,22,.1);background:#ffffffb3}.pill .title .sub{font-size:11px;color:#0b1f1694;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px}.topList .rank-1{border-color:#44c6905c;background-color:#9fffb5}.topList .rank-1 .rankBadge{box-shadow:0 14px 32px #44c69038}.topList .rank-2{border-color:#44c69042;background-color:#b3d1f7}.topList .rank-3{border-color:#0b1f161a;background-color:#fadadd}.rankCard.isSelected{box-shadow:0 16px 40px #44c6902e;border-color:#44c69061;transform:translateY(-1px)}.mapCanvas svg{outline:none}.mapCanvas *:focus{outline:none}.mapCanvas{outline:none}.mapCanvas:focus{outline:none}.mapWrap{position:relative;padding:22px;display:flex;flex-direction:column;min-height:0}.mapOverlay{position:absolute;top:22px;left:22px;right:22px;display:flex;align-items:center;justify-content:space-between;pointer-events:none}.mapOverlay .hint{pointer-events:none;display:flex;gap:8px;align-items:center;background:#ffffffd9;border:1px solid rgba(11,31,22,.1);border-radius:999px;padding:11px 14px;color:#0b1f16cc;font-size:13px;box-shadow:0 10px 22px #0b1f1614}.mapOverlay .selected{pointer-events:none;background:#44c6902e;border:1px solid rgba(68,198,144,.35)}.mapCanvas{flex:1;min-height:0;display:flex;align-items:center;justify-content:center}.infoWrap{display:flex;flex-direction:column;min-height:0}.infoHeader{padding:22px 24px 16px;border-bottom:1px solid var(--line)}.infoHeader.sticky{position:sticky;top:0;z-index:3;background:#ffffffd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.infoHeaderTop{display:flex;align-items:center;justify-content:space-between;gap:12px}.regionChip{background:var(--primary-soft);border:1px solid rgba(68,198,144,.35);color:#0b1f16b8;padding:8px 12px;border-radius:999px;font-weight:800;font-size:12px}.summaryRow{margin-top:14px;display:flex;gap:12px;align-items:flex-end}.summaryItem{flex:0 0 auto;display:flex;align-items:baseline;gap:6px;padding:10px 12px;border-radius:14px;border:1px solid rgba(11,31,22,.1);background:#ffffffb3}.summaryItem b{font-size:16px;letter-spacing:-.2px}.summaryItem span{font-size:12px;color:var(--muted)}.summaryItem:last-child{flex:1 1 auto;justify-content:flex-end;border:none;background:transparent;padding:0}.summaryHint{font-size:12px;color:var(--muted)}.infoHeader h2{margin:0;font-size:16px;letter-spacing:-.3px}.infoHeader p{margin:6px 0 0;font-size:12px;color:var(--muted)}.infoBody{display:grid;gap:18px;min-height:0;max-height:601px;overflow:auto;padding:18px 22px 22px}.card{border:1px solid rgba(11,31,22,.1);border-radius:16px;background:#ffffffdb;padding:16px}.cardTitle{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.cardTitle h3{margin:0;font-size:15px;letter-spacing:-.2px}.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:11px;border:1px solid rgba(11,31,22,.1)}.badge.easy{background:#a6ebcc59}.badge.medium{background:#fff5aa8c}.badge.hard{background:#ffc3c38c}.badge.difficulty{font-weight:700;letter-spacing:-.01em}.difficultyPrefix{font-size:11px;color:#0b1f16a6;font-weight:600}.summaryLegendWrap{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.course{display:flex;justify-content:space-between;gap:10px;padding:12px 14px;border-radius:14px;background:#a6ebcc1f;border:1px solid rgba(11,31,22,.08);margin-top:10px}.course b{font-size:13px}.course span{font-size:12px;color:#0b1f16b3}.difficultyIcon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;font-size:13px;line-height:1}.adBox{border:1px dashed rgba(11,31,22,.22);border-radius:16px;padding:10px 12px;background:#ffffffb3;color:#0b1f1699;font-size:12px}.adInPanel{margin-top:2px}.emptyState{display:flex;gap:14px;align-items:center;padding:18px 16px;border-radius:18px;border:1px solid rgba(11,31,22,.1);background:#a6ebcc24}.emptyIcon{font-size:22px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:#ffffffbf;border:1px solid rgba(11,31,22,.1)}.emptyText{display:flex;flex-direction:column;gap:4px}.emptyText b{font-size:14px}.emptyText span{font-size:12px;color:var(--muted)}.placeCard{border:1px solid rgba(11,31,22,.1);border-radius:18px;background:#ffffffe0;overflow:hidden}.placeHeader{padding:16px 16px 12px;border-bottom:1px solid rgba(11,31,22,.08);background:#ffffffd1}.placeTitle{display:flex;align-items:center;justify-content:space-between;gap:10px}.placeTitle h3{margin:0;font-size:15px;letter-spacing:-.2px}.placeMeta{font-size:12px;color:#0b1f1699}.courseList{display:flex;flex-direction:column}.courseRow{padding:14px 16px;border-top:1px solid rgba(11,31,22,.06)}.courseRow:first-child{border-top:none}.courseMain{display:flex;flex-direction:column;gap:8px}.courseMain b{font-size:13px}.courseSub{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.timeChip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:11px;border:1px solid rgba(11,31,22,.1);background:#fffc;color:#0b1f16b8}.page{flex:1;min-height:0;overflow:auto;padding:18px 18px 20px;background:#ffffffeb;border:1px solid rgba(15,23,42,.1);border-radius:16px;box-shadow:0 6px 18px #0f172a0f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.pageHeader{padding-bottom:12px;margin-bottom:14px;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid rgba(15,23,42,.08)}.pageTitle{margin:0;font-size:16px;font-weight:800;letter-spacing:-.4px;color:#0f172aeb}.pageSubTitle{margin:0;font-size:12px;color:#0f172a8c}.pageBody{font-size:13px;line-height:1.75;color:#0f172ad1}.pageBody p{margin:10px 0}.pageBody h3{margin:18px 0 8px;font-size:13px;font-weight:800;letter-spacing:-.2px;color:#0f172ae6}.pageBody ul{margin:10px 0;padding-left:18px}.pageBody li{margin:6px 0;color:#0f172ac7}.pageBody a{color:inherit;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#0f172a40}.pageBody a:hover{text-decoration-color:#0f172a8c}.pageNotice{margin-top:14px;padding:12px;border-radius:12px;border:1px solid rgba(15,23,42,.1);background:#0f172a08;color:#0f172ab8;font-size:12px}@media (max-width: 768px){.page{padding:14px 14px 16px;border-radius:14px}.pageHeader{padding-bottom:10px;margin-bottom:12px}.pageTitle{font-size:15px}.pageBody{font-size:12.5px;line-height:1.72}.pageBody h3{font-size:12.5px;margin:16px 0 7px}}@media (max-width: 420px){.page{padding:12px 12px 14px;border-radius:12px}.pageTitle{font-size:14px}.pageBody{font-size:12px}}footer.siteFooter{display:flex;justify-content:center;padding:28px 24px;border-top:1px solid var(--line);background:#ffffffeb;color:#0b1f16c7}.footerInner.footerSimple{width:min(1280px,100%);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.footerLeft{max-width:760px}.footerHeading{display:block;font-size:20px;letter-spacing:-.3px;color:#0b1f16e6}.footerDesc{margin:10px 0 0;font-size:14px;line-height:1.55;color:#0b1f16a8}.footerRight{display:flex;flex-direction:column;align-items:flex-end;text-align:right;gap:10px;min-width:240px}.footerLinksV{display:flex;flex-direction:column;gap:10px}.footerLinksV a{text-decoration:none;color:#0b1f16cc;font-size:14px}.footerLinksV a:hover{text-decoration:underline;text-underline-offset:4px}.footerContactLine{font-size:14px;color:#0b1f16b3}.footerContactLine a{color:#0b1f16cc;text-decoration:none}.footerContactLine a:hover{text-decoration:underline;text-underline-offset:4px}.footerCopy{margin-top:6px;font-size:14px;color:#0b1f168c}@media (max-width: 860px){.footerInner.footerSimple{flex-direction:column;align-items:flex-start}.footerRight{align-items:flex-start;text-align:left}}@media (max-width: 980px){main{padding:18px 18px 16px}.contentGrid{grid-template-rows:auto 1fr}.bottomGrid{grid-template-columns:1fr}.topList{display:flex;flex-direction:column;gap:10px;overflow:visible;padding-bottom:0;scroll-snap-type:none}.pill{flex:1 1 auto}.rankBadge{width:40px;height:40px;border-radius:12px}.rankNum{font-size:18px}.rankUnit{font-size:11px}.rankMeta{gap:6px}.metaChip{height:20px;font-size:10px;padding:0 8px}.courseText{font-size:10px}.scoreValue{font-size:13px}.footerTop{flex-direction:column}.footerGrid{grid-template-columns:1fr}.footerBottom{flex-direction:column;align-items:flex-start}.docGrid{grid-template-columns:1fr}}
