@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700;800;900&display=swap";:root{color:#152033;background:#edf1f5;font-family:Inter,Noto Sans KR,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}#metrics,#countries,#selected-country,#details{scroll-margin-top:78px}.app-shell{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#eef3f8 42%,#e8edf3)}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 22px;border-bottom:1px solid #d8e1ec;background:#f8fafcf5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand,.top-actions,.icon-link,.primary-link,.panel-head,.data-toolbar,.filter-row,.country-controls,.hero-metrics,.searchbox,.table-link,.metric-inline{display:flex;align-items:center}.brand{gap:12px;min-width:0}.brand-mark{display:grid;width:34px;height:34px;place-items:center;border:1px solid #c4d2e4;border-radius:8px;color:#1557c0;background:#fff}.brand h1,.brand p,.hero-copy h2,.hero-copy p,.panel h2,.panel-head span{margin:0}.brand h1{font-size:17px;line-height:1.1}.brand p{margin-top:2px;color:#61708a;font-size:13px}.top-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;min-width:0}.top-menu,.admin-actions{display:flex;align-items:center;gap:4px;min-width:0}.top-menu{padding:3px;border:1px solid #cbd7e6;border-radius:8px;background:#fff}.admin-actions{gap:6px}.top-menu-button,.icon-link,.primary-link{display:inline-flex;align-items:center;height:32px;gap:6px;border-radius:8px;padding:0 10px;font-size:12px;font-weight:700;white-space:nowrap}.top-menu-button{border:0;color:#304057;background:transparent}.top-menu-button:hover,.top-menu-button:focus-visible{color:#1557c0;background:#e8f1ff}.icon-link{border:1px solid #cbd7e6;color:#304057;background:#fff}.primary-link{border:1px solid #1f5fbf;color:#fff;background:#1f5fbf}.dashboard-grid{display:grid;grid-template-columns:minmax(260px,318px) minmax(0,1fr);gap:12px;width:min(1480px,100%);margin:0 auto;padding:12px 16px 24px}.sidebar,.panel,.hero-panel,.summary-panel,.summary-button{border:1px solid #d6e0eb;border-radius:8px;background:#ffffffeb;box-shadow:0 12px 28px #1d2c4414}.sidebar{position:sticky;top:70px;align-self:start;height:calc(100vh - 88px);min-height:500px;padding:12px;overflow:hidden}.panel-head{justify-content:space-between;gap:10px;margin-bottom:10px}.panel-head h2{font-size:15px}.panel-head span{display:block;margin-top:4px;color:#68758a;font-size:12px}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.searchbox{gap:8px;height:34px;padding:0 9px;border:1px solid #ccd8e6;border-radius:8px;color:#6b7890;background:#f8fafc}.searchbox input{width:100%;min-width:0;border:0;outline:0;color:#1d293b;background:transparent}.country-controls{gap:8px;margin-top:8px}.sort-select{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;flex:1 1 auto;min-width:0;height:32px;padding:0 8px;border:1px solid #ccd8e6;border-radius:8px;background:#fff}.sort-select span{color:#64748b;font-size:11px;font-weight:900}.sort-select select{min-width:0;border:0;outline:0;color:#25354c;font-size:12px;font-weight:800;background:transparent}.density-toggle{flex:0 0 auto;height:32px;border:1px solid #ccd8e6;border-radius:8px;padding:0 10px;color:#334155;font-size:12px;font-weight:900;background:#fff;white-space:nowrap}.density-toggle.active{border-color:#1f5fbf;color:#fff;background:#1f5fbf}.country-list{display:grid;gap:7px;height:calc(100% - 112px);margin-top:10px;overflow:auto;padding-right:4px}.country-button{display:grid;grid-template-columns:minmax(0,1fr) minmax(74px,auto);grid-template-rows:auto auto;align-content:start;gap:6px 10px;width:100%;min-height:78px;padding:9px;border:1px solid #d7e1ed;border-left:4px solid transparent;border-radius:8px;color:#26364d;text-align:left;background:#fff}.country-list.compact{gap:6px}.country-list.compact .country-button{min-height:62px;padding:7px 8px}.country-list.compact .country-meta span{display:none}.country-list.compact .country-count-grid span{padding:1px 6px;font-size:10px}.country-button:hover,.country-button.selected{border-color:#2b67c7;border-left-color:#2b67c7;background:#f4f8ff}.country-main{display:flex;align-items:center;min-width:0;gap:7px}.country-flag,.hero-flag{flex:0 0 auto;border:1px solid #d7e0ea;object-fit:cover;box-shadow:0 2px 6px #0f172a14}.country-flag{width:22px;height:16px;border-radius:4px}.country-title{min-width:0;overflow:hidden;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.country-meta{display:grid;gap:2px;min-width:0;text-align:right}.country-meta strong{overflow:hidden;font-size:12px;text-overflow:ellipsis;white-space:nowrap}.country-meta span,.metric-card small,.summary-button small,.metric-inline small{color:#728099;font-size:11px}.country-count-grid{display:grid;grid-column:1 / -1;grid-template-columns:repeat(3,minmax(0,1fr));gap:3px;width:100%;min-width:0;max-width:100%;overflow:hidden}.country-count-grid span{border:1px solid #d7e0ea;border-radius:999px;padding:2px 6px;background:#f8fafc;white-space:nowrap}.country-count-grid span{display:inline-flex;align-items:center;justify-content:center;gap:3px;min-height:18px;min-width:0;overflow:hidden;color:#728099;font-size:11px;font-weight:800;line-height:1.2}.country-list.compact .country-count-grid span{min-height:16px}.country-count-grid b,.country-count-grid strong{min-width:0;overflow:hidden;font-weight:900;line-height:1;text-overflow:ellipsis}.country-count-grid b{color:#64748b}.country-count-grid strong{color:#31425d}.content{display:grid;gap:12px;min-width:0}.hero-panel{display:grid;grid-template-columns:minmax(220px,.75fr) minmax(0,1.25fr);align-items:start;gap:12px;padding:14px 16px;border-top:3px solid #1f5fbf}.eyebrow{display:inline-block;margin-bottom:6px;color:#1f5fbf;font-size:12px;font-weight:900;letter-spacing:0;text-transform:uppercase}.hero-copy h2{display:flex;align-items:center;gap:8px;overflow-wrap:anywhere;font-size:26px;line-height:1.12}.hero-flag{width:36px;height:26px;border-radius:6px}.hero-copy p{margin-top:5px;color:#66748a}.hero-status{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.hero-status span{border:1px solid #cdd9e8;border-radius:999px;padding:4px 8px;color:#34445c;font-size:12px;font-weight:800;background:#f8fafc}.hero-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(118px,1fr));gap:8px}.summary-panel{display:grid;gap:10px;padding:10px;border-top:3px solid #1f5fbf}.summary-button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:8px}.summary-button{display:grid;grid-template-columns:auto minmax(0,1fr);grid-template-areas:"icon label" "icon value" "icon hint";align-items:center;gap:2px 8px;min-width:0;min-height:78px;padding:10px;border-top:2px solid #94a3b8;color:#26364d;text-align:left}.summary-button:hover,.summary-button.active{border-color:#1f5fbf;border-top-color:#1f5fbf;background:#f4f8ff}.summary-button.active{box-shadow:inset 0 0 0 1px #1f5fbf,0 12px 28px #1d2c4414}.summary-icon{display:grid;grid-area:icon;width:30px;height:30px;place-items:center;border-radius:8px;color:#1f5fbf;background:#e8f1ff}.summary-label{grid-area:label;min-width:0;overflow:hidden;color:#627087;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.summary-button strong{grid-area:value;overflow-wrap:anywhere;font-size:21px;line-height:1.1}.summary-button small{grid-area:hint;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-ranking,.summary-coverage{min-width:0;border:1px solid #dbe4ee;border-radius:8px;overflow:hidden;background:#fff}.summary-ranking .panel-head{margin:0;padding:10px 12px;border-bottom:1px solid #dbe4ee}.summary-coverage .panel-head{margin:0;padding:10px 12px 6px}.metric-card{display:grid;min-width:0;gap:3px;padding:10px;border:1px solid #d8e2ee;border-top:2px solid #2b67c7;border-radius:8px;background:#fff}.metric-icon{display:grid;width:26px;height:26px;place-items:center;border-radius:8px;color:#1f5fbf;background:#e8f1ff}.metric-card span:not(.metric-icon),.summary-button span:not(.summary-icon){color:#627087;font-size:12px;font-weight:700}.metric-card strong,.summary-button strong{overflow-wrap:anywhere;font-size:21px;line-height:1.1}.error-banner{border:1px solid #ef9a9a;border-radius:8px;padding:12px 14px;color:#9f1239;background:#fff1f2}.panel{min-width:0;padding:12px}.chart-wrap{min-height:220px}.summary-chart{min-height:190px;padding:0 6px 8px}.data-panel{padding:0;overflow:hidden}.data-toolbar{justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid #dbe4ee;background:#fbfdff}.data-toolbar h2,.data-toolbar span{margin:0}.data-toolbar h2{font-size:16px}.data-toolbar>div:first-child>span{display:block;margin-top:4px;color:#68758a;font-size:12px}.view-switch,.filter-row{display:flex;gap:8px}.view-switch{flex-wrap:wrap;justify-content:flex-end}.filter-row{align-items:center;padding:9px 12px;border-bottom:1px solid #dbe4ee;overflow-x:auto;background:#fff}.view-switch button,.filter-button{display:inline-flex;align-items:center;gap:6px;min-height:32px;border:1px solid #d5dfeb;border-radius:8px;padding:0 10px;color:#334155;font-weight:800;background:#fff;white-space:nowrap}.view-switch button.active,.filter-button.active{border-color:#1f5fbf;color:#fff;background:#1f5fbf}.view-switch button span,.filter-button span{min-width:22px;border-radius:999px;padding:2px 6px;color:inherit;background:#ffffff38}.filter-label{display:inline-flex;align-items:center;gap:6px;min-height:34px;color:#526178;font-size:12px;font-weight:900;white-space:nowrap}.table-scroll{width:100%;overflow-x:auto}table{width:100%;min-width:940px;border-collapse:collapse}.compact-table table{min-width:860px}thead{position:sticky;top:0;z-index:1}th,td{border-bottom:1px solid #e3e9f1;padding:8px 10px;text-align:left;vertical-align:middle}th{color:#475569;font-size:12px;font-weight:900;background:#eef4fb}td{color:#26364d;font-size:13px}tbody tr{background:#fff}tbody tr:hover{background:#f7fbff}.country-rank-row{cursor:pointer}.country-rank-row.selected{background:#f4f8ff}.country-table-name{display:inline-flex;align-items:center;gap:7px;min-width:0;max-width:260px;font-weight:800}.country-table-name span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.community-row.local td:first-child{box-shadow:inset 4px 0 #2563eb}.community-row.global td:first-child{box-shadow:inset 4px 0 #16a34a}.table-link{gap:6px;min-width:0;color:#1d4ed8;font-weight:800}.table-subtext{display:block;margin-top:4px;color:#738097;font-size:11px;font-weight:700}.rank-cell{display:inline-grid;min-width:34px;height:24px;place-items:center;border-radius:8px;color:#133f91;font-weight:900;background:#e8f1ff}.source-cell{display:inline-block;max-width:150px;overflow:hidden;color:#475569;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.traffic-evidence{display:grid;gap:3px;min-width:120px}.traffic-evidence small{color:#728099;font-size:11px;font-weight:700}.category-rank{display:inline-grid;min-width:34px;height:24px;place-items:center;border:1px solid #d7e0ea;border-radius:8px;color:#334155;font-weight:900;background:#f8fafc}.category-badge{display:inline-flex;align-items:center;min-height:24px;border:1px solid #cfdbea;border-radius:999px;padding:0 8px;color:#334155;font-size:12px;font-weight:900;background:#f8fafc;white-space:nowrap}.category-badge.global{border-color:#b7d7c4;color:#166534;background:#ecfdf3}.category-badge.local{border-color:#bfd3f8;color:#1d4ed8;background:#eff6ff}.metric-inline{flex-wrap:wrap;gap:4px 6px}.metric-inline strong{font-weight:900}.empty-state{padding:24px 12px;color:#6f7c91;text-align:center}@media(max-width:1180px){.dashboard-grid,.hero-panel{grid-template-columns:1fr}.sidebar{position:static;height:auto;min-height:0}.country-list{grid-template-columns:repeat(2,minmax(0,1fr));height:auto;max-height:420px}}@media(min-width:1181px)and (max-width:1360px){.dashboard-grid{grid-template-columns:minmax(250px,300px) minmax(0,1fr);padding:10px 12px 20px}.topbar{padding:10px 18px}.top-menu-button,.icon-link,.primary-link{padding:0 8px}.hero-copy h2{font-size:24px}.metric-card strong,.summary-button strong{font-size:20px}}@media(max-width:760px){.topbar{align-items:flex-start;flex-direction:column;padding:12px 14px}.top-actions{justify-content:flex-start;width:100%}.top-menu,.admin-actions{width:100%;overflow-x:auto}.dashboard-grid{padding:10px}.hero-panel{padding:12px}.hero-copy h2{font-size:22px}.hero-metrics,.summary-button-grid,.country-list{grid-template-columns:1fr}.country-controls{align-items:stretch;flex-direction:column}.density-toggle{width:100%}.panel{padding:12px}.data-toolbar{align-items:stretch;flex-direction:column}.view-switch{justify-content:flex-start}.filter-row{padding:10px}}
