:root{
  --paper:#ece2c8;--paper-a:rgba(247,241,225,.94);--paper-b:rgba(236,225,198,.94);--paper-2:#fff7e7;--ink:#3f2d17;--ink-soft:#7a6138;--muted:#8b7044;--gold:#bd9a55;--gold-soft:rgba(189,154,85,.45);--red:#9c2f1b;--red-2:#7f2419;--jade:#6f8c5a;--blue:#4f8b8a;--shadow:0 18px 45px rgba(63,45,23,.22);--elev:0 8px 28px rgba(62,42,15,.18);--font-display:"Kaiti SC","STKaiti","KaiTi",serif;--font-body:"PingFang SC","Microsoft YaHei",system-ui,sans-serif
}
*{box-sizing:border-box}html,body{height:100%;margin:0;overflow:hidden}body{font-family:var(--font-body);color:var(--ink);background:var(--paper)}button,input,select{font:inherit;color:inherit}button{cursor:pointer}.app{position:relative;width:100vw;height:100vh;overflow:hidden;background:#d9cca9}.map-viewport{position:absolute;inset:0;overflow:hidden;background:#d8c797}.map-canvas,#map{position:absolute;inset:0;z-index:0;background:#ece2c8}html,body,.app,.map-viewport,#map,.map-canvas,.maplibregl-map,.maplibregl-canvas,.maplibregl-canvas-container,.maplibregl-canvas-container.maplibregl-interactive,.maplibregl-canvas-container.maplibregl-touch-drag-pan,.maplibregl-canvas-container.maplibregl-touch-zoom-rotate,.maplibregl-interactive,.maplibregl-marker,.umk{cursor:grab!important}.maplibregl-canvas:active,.maplibregl-canvas-container:active,body.map-dragging,body.map-dragging *{cursor:grabbing!important}.maplibregl-control-container{font-family:var(--font-body)}.maplibregl-ctrl-top-right{top:10px;right:10px}.maplibregl-ctrl-group{background:rgba(255,248,229,.9);border:1px solid var(--gold-soft);box-shadow:var(--elev)}
.paper-grain{position:absolute;inset:0;z-index:2;pointer-events:none;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='linear' slope='0.07'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E")}.vignette{position:absolute;inset:0;z-index:3;pointer-events:none;background:radial-gradient(ellipse at center,transparent 55%,rgba(92,68,30,.28) 100%)}.weather{position:absolute;inset:0;z-index:4;pointer-events:none;overflow:hidden}.weather.rain:before,.weather.snow:before{content:"";position:absolute;inset:-30%;opacity:.35;animation:weatherFall 1.2s linear infinite}.weather.rain:before{background:repeating-linear-gradient(115deg,transparent 0 19px,rgba(84,117,119,.42) 20px 21px,transparent 22px 38px)}.weather.snow:before{background-image:radial-gradient(circle,rgba(255,255,255,.86) 0 1px,transparent 1.5px);background-size:34px 34px;animation-duration:3s}@keyframes weatherFall{to{transform:translate3d(-40px,80px,0)}}
.titlebar{position:absolute;top:18px;left:50%;transform:translateX(-50%);z-index:12;text-align:center;pointer-events:none;animation:fadeDown 1.1s .2s cubic-bezier(.22,1,.36,1) backwards}.titlebar h1{margin:0;font:600 22px/1.2 var(--font-display);color:#4a3414;letter-spacing:2px;white-space:nowrap;text-shadow:0 1px 0 rgba(255,250,238,.5)}.titlebar p{margin:4px 0 0;font-size:12px;color:#7a5f33;letter-spacing:1px;white-space:nowrap}@keyframes fadeDown{from{opacity:0;transform:translate(-50%,-14px)}to{opacity:1;transform:translate(-50%,0)}}@keyframes fadeUp{from{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%,0)}}
.toolbar{position:absolute;top:14px;left:14px;z-index:18;display:flex;flex-direction:column;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));border:1px solid var(--gold-soft);border-radius:13px;box-shadow:var(--elev);overflow:hidden;backdrop-filter:blur(10px) saturate(1.04)}.tbtn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:none;border:0;color:var(--ink-soft);padding:0;transition:background .2s,color .2s,transform .15s}.tbtn+.tbtn{border-top:1px solid rgba(189,154,85,.32)}.tbtn svg{width:21px;height:21px;display:block}.tbtn:hover{background:rgba(189,154,85,.16);color:var(--ink)}.tbtn:active{transform:scale(.88)}.tbtn.on,.tbtn.active{background:var(--red);color:#fbf0df}.toolbar:not(.more-open) .tbtn.extra{display:none}.cfgbtn{display:none;position:absolute;top:14px;left:14px;z-index:19;width:42px;height:42px;border-radius:13px;border:1px solid var(--gold-soft);background:linear-gradient(180deg,var(--paper-a),var(--paper-b));box-shadow:var(--elev);color:var(--ink-soft);font-size:18px}.tb-flyout{position:fixed;z-index:80;pointer-events:none;opacity:0;white-space:nowrap;background:rgba(63,50,32,.93);color:#f7efdc;font:600 12px/1 var(--font-display);letter-spacing:.5px;padding:6px 11px;border-radius:8px;box-shadow:0 3px 10px rgba(60,40,15,.3);transition:opacity .16s ease,transform .16s ease}.tb-flyout.show{opacity:1}.tb-flyout[data-dir="r"]{transform:translateY(-50%) translateX(-6px)}.tb-flyout[data-dir="r"].show{transform:translateY(-50%) translateX(0)}.tb-flyout[data-dir="u"]{transform:translate(-50%,-100%) translateY(6px)}.tb-flyout[data-dir="u"].show{transform:translate(-50%,-100%) translateY(0)}.zoomctl{display:none}
.searchbar{position:absolute;top:70px;left:50%;transform:translateX(-50%);z-index:20;width:min(360px,86vw);text-align:center;pointer-events:auto}.searchbar,.searchbar *{pointer-events:auto}.searchbox{height:40px;display:flex;align-items:center;gap:8px;padding:0 10px 0 14px;border:1px solid var(--gold-soft);border-radius:999px;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));box-shadow:var(--elev);backdrop-filter:blur(10px)}.search-ico{color:#8a6a45;flex:none}.searchbox input{width:100%;border:0;outline:0;background:transparent;font-size:14px;padding:0;cursor:text;-webkit-appearance:none;appearance:none;pointer-events:auto}.search-clear{width:24px;height:24px;border:0;border-radius:50%;background:rgba(157,47,27,.08);color:var(--red);display:grid;place-items:center;font-size:11px}.search-clear:hover{background:var(--red);color:#fbf0df}.searchbar p{margin:7px 0 0;font-size:12px;color:#8b7044;letter-spacing:.5px}.searchbar p button{border:0;background:transparent;color:var(--red);font-weight:700;padding:0 2px}.search-results{display:none;margin-top:8px;max-height:54vh;overflow:auto;border:1px solid var(--gold-soft);border-radius:12px;background:linear-gradient(180deg,rgba(247,241,225,.97),rgba(236,225,198,.97));box-shadow:var(--elev);backdrop-filter:blur(10px);padding:6px;text-align:left}.search-results.open{display:grid;gap:4px;animation:panelPop .22s ease-out}.sr-item{display:grid;grid-template-columns:auto 1fr auto;gap:9px;align-items:center;width:100%;border:0;border-radius:9px;background:transparent;padding:8px;text-align:left}.sr-item:hover,.sr-item.sr-active{background:rgba(189,154,85,.2);box-shadow:inset 0 0 0 1px rgba(189,154,85,.3)}.sr-seal{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;background:var(--red);color:#fff4dd;font:700 14px var(--font-display)}.sr-main{min-width:0}.sr-main b{display:block;font:700 13px var(--font-display);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-main small{display:block;margin-top:2px;color:#8b7044;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px}.sr-rank{font-size:11px;color:#a17d3c}.sr-empty{padding:12px;color:#8b7044;text-align:center}@keyframes panelPop{from{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:none}}
.botbar{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:18;display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center;max-width:94vw;animation:fadeUp 1s .55s cubic-bezier(.22,1,.36,1) backwards}.region-dd{position:relative}.region-trigger,.seg{display:inline-flex;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));border:1px solid var(--gold-soft);border-radius:999px;box-shadow:var(--elev);overflow:hidden;backdrop-filter:blur(10px)}.region-trigger{align-items:center;gap:7px;padding:8px 12px;color:var(--ink-soft)}.rg-pin{width:17px;height:17px;color:var(--red)}.rg-caret{width:14px;height:14px;transition:.18s}.region-trigger[aria-expanded="true"] .rg-caret{transform:rotate(180deg)}.region-pop{position:absolute;left:0;bottom:calc(100% + 8px);width:156px;max-height:300px;overflow:auto;padding:6px;border-radius:12px;border:1px solid var(--gold-soft);background:linear-gradient(180deg,var(--paper-a),var(--paper-b));box-shadow:var(--elev)}.region-opt{position:relative;padding:7px 12px 7px 26px;border-radius:8px;cursor:pointer;font:500 13px var(--font-display);color:var(--ink-soft);white-space:nowrap}.region-opt:hover,.region-opt[aria-selected="true"]{background:rgba(189,154,85,.17);color:var(--ink)}.region-opt[aria-selected="true"]:before{content:"✓";position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--red)}.seg{display:inline-flex}.seg-i{font:500 13px/1 var(--font-display);letter-spacing:1px;padding:9px 15px;background:none;border:0;color:var(--ink-soft);white-space:nowrap;transition:.2s}.seg-i+.seg-i{border-left:1px solid rgba(189,154,85,.32)}.seg-i:hover{background:rgba(189,154,85,.16);color:var(--ink)}.seg-i.on{background:var(--red);color:#fbf0df;box-shadow:0 0 0 1px rgba(216,192,138,.5) inset}.acts{display:inline-flex;gap:8px}.actbtn{font:600 13px/1 var(--font-display);letter-spacing:1px;padding:10px 16px;border-radius:999px;white-space:nowrap;color:#fbf0df;border:1px solid var(--gold);background:linear-gradient(180deg,#a8392a,#8c2f1b);box-shadow:0 4px 12px rgba(156,47,27,.3),0 0 0 1px rgba(216,192,138,.4) inset;transition:.25s}.actbtn:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(156,47,27,.4),0 0 0 1px rgba(216,192,138,.55) inset}.actbtn.on{background:linear-gradient(180deg,#7a2417,#5f1c11)}
.favbtn,.luckbtn{position:absolute;z-index:18;border:1px solid var(--gold-soft);border-radius:999px;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));box-shadow:var(--elev);padding:10px 18px;color:var(--red);font-weight:800}.favbtn{right:18px;bottom:26px}.luckbtn{left:18px;bottom:26px}
.panel{position:absolute;z-index:35;width:300px;max-height:calc(100vh - 34px);overflow:auto;padding:18px;border:1px solid rgba(204,167,92,.82);border-radius:16px;background:linear-gradient(180deg,rgba(255,249,233,.97),rgba(246,232,202,.97));box-shadow:var(--shadow);transform:translateX(-118%);transition:transform .38s cubic-bezier(.22,1,.36,1),opacity .25s;opacity:0;pointer-events:none;visibility:hidden}.panel.open{transform:translateX(0);opacity:1;pointer-events:auto;visibility:visible}.rec-panel,.quiz-panel{left:72px;top:84px}.fav-panel{right:18px;bottom:78px;top:auto;transform:translateY(20px);width:340px;max-height:60vh}.fav-panel.open{transform:translateY(0)}.stats-panel{left:50%;top:50%;right:auto;width:min(760px,calc(100vw - 36px));max-height:min(720px,calc(100vh - 60px));transform:translate(-50%,-48%) scale(.96);opacity:0}.stats-panel.open{transform:translate(-50%,-50%) scale(1);opacity:1}.panel h2{margin:0 36px 14px 0;font:700 21px/1.2 var(--font-display);letter-spacing:2px}.panel h2 span{font:500 12px/1 var(--font-body);color:var(--muted);letter-spacing:0}.panel-close,.welcome-x{position:absolute;right:14px;top:12px;border:0;background:transparent;color:#87672f;font-size:18px}.segmented{display:flex;padding:4px;border:1px solid rgba(203,174,112,.6);border-radius:999px;background:rgba(255,251,238,.7);margin-bottom:14px}.segmented button{flex:1;border:1px solid transparent;border-radius:999px;background:transparent;padding:7px 12px;font-size:13px;color:#6e552d}.segmented button.active{background:var(--red);color:#fff1dc}.segmented.compact button{font-size:12px;padding:6px 10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}label{font-size:12px;color:#7c6134}select,input{border:1px solid rgba(203,174,112,.72);border-radius:10px;background:rgba(255,252,242,.86);padding:10px 12px;outline:0}label select,.wide-input input{display:block;width:100%;margin-top:5px}.wide-input{display:block;margin:12px 0}.electives,.mini-checks{display:flex;flex-wrap:wrap;gap:7px;margin:10px 0}.electives button,.mini-checks button,.weather-picks button{border:1px solid rgba(203,174,112,.72);border-radius:999px;background:rgba(255,252,242,.8);padding:7px 11px;color:#73542a}.electives button.active,.mini-checks button.active,.weather-picks button.active{background:#7f2419;color:#fff4dd}.more-filter{margin:8px 0 14px;color:#7c6134}.primary,.welcome-hero button{width:100%;border:0;border-radius:10px;background:var(--red);color:#fff4dd;font-weight:800;letter-spacing:3px;padding:13px 16px;box-shadow:0 10px 22px rgba(169,47,29,.22)}.tour-primary{display:none;width:100%;margin-top:9px;border:1px solid rgba(203,174,112,.78);border-radius:999px;background:#fff9ea;color:var(--red);font-weight:800;letter-spacing:2px;padding:10px 14px}.tour-primary.show{display:block}.note{font-size:11px;line-height:1.5;color:#92764b}.result-stack{display:grid;gap:10px;margin-top:14px}.result-card{border:1px solid rgba(203,174,112,.68);border-radius:12px;background:rgba(255,253,246,.72);padding:12px}.result-head{display:flex;justify-content:space-between;gap:10px;align-items:start}.result-card h3{margin:0;font-size:15px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}.tag,.band{display:inline-flex;align-items:center;border-radius:999px;padding:3px 8px;font-size:11px;background:#ead9b8;color:#6f4f20}.band{font-weight:800;color:#fff}.band.冲{background:#a92f1d}.band.稳{background:#6f8c5a}.band.保{background:#4f8b8a}.band.相近{background:#8a6a45}.card-actions{display:flex;gap:8px;margin-top:9px}.card-actions button,.fav-actions button{border:1px solid rgba(203,174,112,.72);border-radius:999px;background:#fff9ea;padding:7px 11px;font-size:12px}
.detail-card{position:absolute;z-index:33;left:72px;bottom:auto;top:132px;width:300px;transform:translateX(-14px);opacity:0;pointer-events:none;border:1px solid rgba(203,174,112,.78);border-radius:16px;background:rgba(255,248,229,.96);box-shadow:var(--shadow);padding:14px;transition:.25s}.detail-card.open{opacity:1;transform:none;pointer-events:auto}.detail-card h3{margin:0 0 4px;font-size:18px}.detail-card .seal{float:left;width:44px;height:44px;border-radius:12px;margin:0 12px 8px 0;background:var(--red);color:#fff4dd;display:grid;place-items:center;font:700 20px var(--font-display)}.settings-pop{position:absolute;z-index:42;left:68px;top:150px;width:220px;padding:14px;border:1px solid rgba(203,174,112,.78);border-radius:14px;background:rgba(255,248,229,.96);box-shadow:var(--shadow);display:none}.settings-pop.open{display:block}.settings-pop h3{margin:0 0 10px;font:700 17px var(--font-display)}.settings-pop label{display:block;margin:9px 0}.weather-picks{display:flex;gap:8px;margin-top:12px}
.ob-mask{position:absolute;inset:0;z-index:50;background:rgba(60,45,20,.36);display:none;backdrop-filter:blur(2px)}.ob-mask.show{display:block;animation:fadeUp .3s ease}.welcome{display:none}.welcome.hidden{display:none!important}.onboard{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.96);z-index:51;width:min(440px,92vw);opacity:0;padding:22px 24px 20px;border-radius:16px;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));border:1px solid var(--gold-soft);box-shadow:var(--elev);backdrop-filter:blur(12px);transition:opacity .35s ease,transform .4s cubic-bezier(.22,1,.36,1)}.onboard.show{display:block;opacity:1;transform:translate(-50%,-50%) scale(1)}.onboard .x{position:absolute;top:9px;right:13px;cursor:pointer;color:#7d6536;font-size:17px;background:none;border:0}.onboard h2{margin:0 0 4px;font:600 19px var(--font-display);color:var(--ink);letter-spacing:2px;display:flex;align-items:center;gap:8px}.onboard h2:before{content:"";width:3px;height:18px;background:var(--red);border-radius:1px;flex:0 0 auto}.ob-sub{margin:0 0 14px;font:500 13px var(--font-display);color:var(--ink-soft);line-height:1.5}.ob-hero{background:rgba(157,47,27,.06);border:1px solid var(--gold-soft);border-radius:12px;padding:14px;margin:0 0 11px;text-align:center}.ob-hero strong{display:block;font:600 15.5px var(--font-display);color:var(--ink);letter-spacing:1px;margin-bottom:3px}.ob-hero span{display:block;font-size:11.5px;color:var(--ink-soft);margin-bottom:12px}.ob-hero button{display:block;width:100%;padding:12px;border:0;border-radius:10px;cursor:pointer;color:#fbf0df;background:var(--red);font:600 15px var(--font-display);letter-spacing:1.5px;box-shadow:0 4px 14px rgba(156,47,27,.32)}.ob-funnel{font-size:11px;color:#a8916a;text-align:center;margin:0 0 9px}.ob-acts{display:flex;gap:10px}.ob-acts button{border:1px solid var(--gold);border-radius:999px;background:#fdf8ea;color:var(--red);font:600 13.5px var(--font-display);letter-spacing:1px;padding:10px 16px}.ob-acts button:last-child{color:var(--ink-soft);border-color:var(--gold-soft);font-weight:500}.ob-bgm{display:flex;align-items:center;justify-content:center;gap:7px;margin:12px 0 0;cursor:pointer;font:500 12.5px var(--font-display);color:var(--ink-soft)}
.loader{position:absolute;left:50%;bottom:92px;z-index:24;transform:translateX(-50%);display:flex;gap:8px;align-items:center;padding:7px 13px;border-radius:999px;background:rgba(255,248,229,.84);font-size:12px;color:#85673a;box-shadow:0 8px 20px rgba(63,45,23,.14)}.loader.done{display:none}.loadbar{position:absolute;top:112px;right:14px;z-index:16;display:flex;align-items:center;gap:7px;padding:6px 12px 8px;border-radius:14px;background:rgba(247,241,225,.93);border:1px solid rgba(170,130,70,.42);box-shadow:0 2px 11px rgba(70,48,22,.13);color:#6b5836;font-size:12px;line-height:1;white-space:nowrap;overflow:hidden;opacity:0;transform:translateY(-5px);transition:.3s;pointer-events:none}.loadbar.show{opacity:1;transform:none}.loadbar i{width:11px;height:11px;border-radius:50%;border:2px solid rgba(150,110,60,.28);border-top-color:#a8691f;animation:lbspin .8s linear infinite;flex:none}.loadbar b{color:#a8691f}.loadbar em{position:absolute;left:0;bottom:0;height:2.5px;background:linear-gradient(90deg,#caa05a,#a8691f);width:0;transition:width .25s ease}@keyframes lbspin{to{transform:rotate(360deg)}}.toast{position:absolute;left:50%;bottom:92px;z-index:90;transform:translate(-50%,20px);opacity:0;border-radius:999px;background:#3f2d17;color:#fff4dd;padding:10px 16px;box-shadow:var(--shadow);transition:.25s;font-size:13px}.toast.show{opacity:1;transform:translate(-50%,0)}
.plabel{font:700 12px var(--font-display);color:rgba(75,55,24,.72);letter-spacing:2px;pointer-events:none;text-shadow:0 1px 1px rgba(255,248,229,.86)}.landmark-map{display:flex;flex-direction:column;align-items:center;pointer-events:none;opacity:.83}.landmark-map i{color:#a92f1d;font-style:normal;font-size:10px;line-height:1}.landmark-map span{font:700 11px var(--font-display);color:#7d5a29;letter-spacing:1px;white-space:nowrap;text-shadow:0 1px 1px rgba(255,248,229,.75)}.maplibregl-marker{will-change:transform}.umk{transition:opacity .25s ease; user-select:none; -webkit-user-select:none; pointer-events:auto; }.umk *{pointer-events:none}.umk .flag{position:absolute;left:0;bottom:0;opacity:0;pointer-events:none;transform:scale(.55) translateY(8px);transform-origin:bottom center;transition:opacity .3s ease,transform .5s cubic-bezier(.34,1.56,.64,1)}.umk.show-flag .flag{opacity:1;transform:none;pointer-events:auto}.umk .dot{position:absolute;left:0;bottom:0;width:6px;height:6px;border-radius:50%;border:1px solid rgba(255,250,235,.9);box-shadow:0 1px 2px rgba(80,55,20,.3);transform:translate(-50%,50%);background:#8f8676;animation:pop .55s cubic-bezier(.34,1.56,.64,1) var(--d,0ms) backwards}.umk.show-flag .dot{opacity:0;pointer-events:none}@keyframes pop{from{transform:translate(-50%,50%) scale(0)}to{transform:translate(-50%,50%) scale(1)}}.banner{position:absolute;left:0;bottom:var(--bh,13px);transform:translateX(calc(-50% + var(--lx,0px)));display:flex;flex-direction:column;align-items:center;gap:3px;font:700 12px/1 var(--font-display);padding:6px 3px;border-radius:2px;box-shadow:1px 2px 3px rgba(80,55,20,.35);white-space:nowrap;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}.umk:hover .banner{transform:translateX(calc(-50% + var(--lx,0px))) scale(1.13) rotate(2.5deg)}.bname{writing-mode:vertical-rl;letter-spacing:2px}.bdg{width:21px;height:21px;border-radius:50%;background:rgba(255,250,238,.96);color:#8c2f1b;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 1px 2px rgba(60,40,15,.35);font:900 12px var(--font-display);flex:none}.bfull{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%) rotate(-2.5deg);background:rgba(47,35,18,.93);color:#f7ecd9;font:700 11px/1.1 var(--font-display);letter-spacing:1px;padding:4px 9px;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s ease;box-shadow:0 2px 7px rgba(60,40,15,.42);z-index:6}.umk:hover .bfull{opacity:1}.pole{position:absolute;left:0;bottom:0;width:2px;margin-left:-1px;height:var(--plen,13px);transform-origin:bottom center;transform:rotate(var(--lean,0deg))}.t985 .banner,.t985 .pole{background:#8c2f1b;color:#f7e8d6}.t211 .banner,.t211 .pole{background:#96660f;color:#f7e8d6}.tdfc .banner,.tdfc .pole{background:#564a85;color:#ece9f7}.tben .banner,.tben .pole{background:#6b6357;color:#f2ece0}.t985 .dot{background:#c34a26}.t211 .dot{background:#c08a2a}.tdfc .dot{background:#8077c9}.umk.tben{z-index:11}.umk.tdfc{z-index:12}.umk.t211{z-index:13}.umk.t985{z-index:14}.umk.rec .banner,.umk.rec-temp .banner{outline:2px solid rgba(232,192,94,.92);outline-offset:2px;animation:selPulse 1.6s ease-out infinite}.umk.rec-冲 .banner{outline-color:#d85a30}.umk.rec-稳 .banner{outline-color:#e0a32e}.umk.rec-保 .banner{outline-color:#1d9e75}.umk.rec .dot,.umk.rec-temp .dot{background:#e8c05e}.umk.sel{z-index:80!important}.umk.sel .banner{outline:2.5px solid var(--red);outline-offset:2px;animation:selPulse 1.6s ease-out infinite}@keyframes selPulse{0%{box-shadow:1px 2px 4px rgba(80,55,20,.4),0 0 0 0 rgba(156,47,27,.5)}70%,100%{box-shadow:1px 2px 4px rgba(80,55,20,.4),0 0 0 11px rgba(156,47,27,0)}}body.map-moving .umk:not(.sel):not(.rec){opacity:.35;pointer-events:none}body.sel-focus .umk:not(.sel){opacity:.2!important}body.rec-mode .umk:not(.rec):not(.rec-temp){opacity:.12!important;pointer-events:none}.labels-off .umk .banner{display:none!important}.labels-off .umk.show-flag .dot{opacity:1;pointer-events:auto}
.detail-lines{clear:both;margin-top:9px}.tlabel{margin:8px 0 5px;font-size:12px;color:#7f6538;font-weight:800}.trow{display:grid;grid-template-columns:minmax(72px,1.1fr) 1fr auto;gap:7px;align-items:center;margin:5px 0;font-size:11px}.tmj{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pbar{height:8px;border-radius:999px;background:#ead9b8;overflow:hidden}.pbar i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#d4aa50,#a92f1d)}.tval{color:#7f6538;white-space:nowrap}.fav-actions{display:flex;gap:8px;margin-bottom:10px}.fav-meta-line{font-size:12px;color:#7f6538;margin-bottom:9px}.fav-list{display:grid;gap:8px}.fav-row{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;border:1px solid rgba(203,174,112,.58);border-radius:10px;background:rgba(255,253,246,.74);padding:9px}.fav-seq{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#ead9b8;color:#6f4f20;font-size:12px;font-weight:800}.fav-x{border:0;background:transparent;color:var(--red);font-weight:900}.empty{padding:20px;border:1px dashed rgba(203,174,112,.8);border-radius:12px;text-align:center;color:#8d7042}.stats-bars{display:grid;gap:10px}.barrow{display:grid;grid-template-columns:72px 1fr 42px;align-items:center;gap:9px;font-size:12px}.bar{height:12px;border-radius:999px;background:#ead9b8;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,#a92f1d,#d4aa50);border-radius:inherit}.quiz-question{border:1px solid rgba(203,174,112,.65);border-radius:14px;background:rgba(255,253,246,.72);padding:14px}.quiz-question h3{margin:4px 0 12px;font-size:16px}.quiz-options{display:grid;gap:8px}.quiz-options button{border:1px solid rgba(203,174,112,.72);border-radius:10px;background:#fff9ea;padding:10px;text-align:left}.progress{height:8px;border-radius:999px;background:#ead9b8;overflow:hidden;margin:0 0 12px}.progress i{display:block;height:100%;background:var(--red)}.score-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.score-grid span{border-radius:9px;background:#ead9b8;padding:8px;text-align:center;font-size:12px}.vizctl{display:flex;justify-content:space-between;gap:10px;align-items:center;margin:6px 0 10px;color:#6f552d;font-size:12px}.rank-chart svg{width:100%;height:auto;display:block;background:rgba(255,253,246,.45);border:1px solid rgba(203,174,112,.55);border-radius:12px}.vizleg{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:8px 0 0;font-size:11px;color:#6f552d}.vizleg span{display:inline-flex;align-items:center;gap:4px}.vizleg i{display:inline-block;width:10px;height:10px;border-radius:3px}.dim{color:#9a8053}
.fav-row{cursor:pointer}.fav-row:hover,.fav-g:hover{background:rgba(255,251,238,.92)}.fav-prov{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 9px;border:1px solid rgba(203,174,112,.58);border-radius:12px;background:rgba(255,253,246,.66)}.fav-prov span:first-child{min-width:0}.fav-prov b{font-weight:700;color:#6f552d}.fav-prov-sel{max-width:84px;padding:5px 8px;border-radius:999px;background:#fff9ea}.fav-fill{white-space:nowrap;font-weight:800;color:#6f8c5a}.fav-fill.over,.fav-g-h.over{color:var(--red)}.fav-risk{border-radius:11px;padding:8px 10px;font-size:12px;line-height:1.45;border:1px solid rgba(203,174,112,.62)}.fav-risk.ok{background:rgba(111,140,90,.1);color:#55723f}.fav-risk.warn{background:rgba(156,47,27,.08);color:var(--red)}.fav-g{border:1px solid rgba(203,174,112,.58);border-radius:12px;background:rgba(255,253,246,.62);overflow:hidden;cursor:pointer}.fav-g-h{display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;padding:9px}.fav-sub{margin:0 8px 8px 36px;grid-template-columns:22px 1fr auto}.fav-sub-n{width:20px;height:20px;border-radius:50%;display:grid;place-items:center;background:#f0e2c5;color:#7f6538;font-size:11px}.fav-meta{min-width:0}.fav-nm{display:block;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-mj{display:block;margin-top:2px;font-size:11px;color:#7f6538;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fav-dim{color:#9a8053}.fav-grp{font-size:12px;color:#7f6538;font-weight:800;margin-top:2px}
.umk:hover{z-index:90!important}.umk.show-flag .banner{pointer-events:auto}.umk.show-flag .banner *{pointer-events:none}.umk .crest{width:29px;height:29px;border-radius:50%;display:grid;place-items:center;margin:0 0 5px;background:#fff8e8;border:1px solid rgba(255,244,218,.95);box-shadow:0 2px 9px rgba(56,38,16,.38);overflow:hidden;opacity:0;transform:translateY(8px) scale(.72);transition:opacity .18s ease,transform .28s cubic-bezier(.34,1.56,.64,1)}.umk .crest img{width:100%;height:100%;display:block;object-fit:cover}.crest-fallback{width:100%;height:100%;display:grid;place-items:center;color:#8c2f1b;background:#fff8e8;font:900 13px var(--font-display)}.umk:hover .crest,.umk.sel .crest{opacity:1;transform:translateY(0) scale(1)}.umk:hover .banner,.umk.sel .banner{transform:translateX(calc(-50% + var(--lx,0px))) scale(1.13) rotate(2.5deg)}.bfull{left:calc(100% + 8px);top:42%;right:auto;bottom:auto;transform:translateY(-50%) translateX(-4px);padding:5px 10px;border-radius:6px;background:rgba(43,31,16,.94);font-size:12px;line-height:1.15;letter-spacing:1px;transition:opacity .18s ease,transform .22s ease}.umk:hover .bfull,.umk.sel .bfull{opacity:1;transform:translateY(-50%) translateX(0)}.detail-card .seal.seal-logo{background:#fff8e8;border:1px solid rgba(203,174,112,.7);overflow:hidden}.detail-card .seal.seal-logo img{width:100%;height:100%;object-fit:cover;display:block}.detail-card .seal.seal-logo span{display:none;width:100%;height:100%;place-items:center;background:var(--red);color:#fff4dd}.prof-row{display:grid;grid-template-columns:minmax(92px,.9fr) 1fr;gap:7px;align-items:start;margin:6px 0;padding:7px 8px;border:1px solid rgba(203,174,112,.48);border-radius:9px;background:rgba(255,253,246,.58);font-size:11px}.prof-major{font-weight:800;color:#593d1d;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prof-meta{color:#7f6538;line-height:1.35;min-width:0}
.umk .banner{gap:2px;font-size:10.5px;line-height:1.05;padding:4px 2px 5px;min-width:22px;border-radius:2px;box-shadow:1px 2px 3px rgba(63,38,18,.32)}.umk .crest{width:22px;height:22px;margin:-1px 0 3px;opacity:1;transform:none;box-shadow:0 1px 4px rgba(44,30,14,.28);border-color:rgba(255,246,226,.96)}.umk .crest-fallback,.crest-fallback{font-size:10px}.umk .bname{letter-spacing:1px;line-height:1.06;font-weight:800}.bdg{display:none!important}.umk .pole{width:1.5px;margin-left:-.75px;height:var(--plen,10px)}.umk .dot{width:5px;height:5px;border-width:1px}.umk:hover .banner,.umk.sel .banner{transform:translateX(calc(-50% + var(--lx,0px))) scale(1.06) rotate(1.5deg)}.umk:hover .crest,.umk.sel .crest{opacity:1;transform:translateY(-1px) scale(1.04)}.umk .bfull{left:calc(100% + 6px);top:37%;padding:4px 8px;border-radius:5px;font-size:11px;letter-spacing:.5px;box-shadow:0 2px 6px rgba(46,31,14,.36)}
.school-detail-page{position:fixed;inset:0;z-index:78;overflow:auto;background:#f6f8fb;color:#061229;font-family:"PingFang SC","Microsoft YaHei",system-ui,sans-serif;cursor:auto!important}.school-detail-page *{cursor:auto!important}.school-detail-page button,.school-detail-page a,.school-detail-page select{cursor:pointer!important}.school-detail-open .welcome,.school-detail-open .ob-mask{display:none!important}.sd-wrap{width:min(1760px,calc(100vw - 44px));margin:22px auto 48px}.sd-back{min-height:40px;margin:0 0 12px;border:1px solid #cddbe8;border-radius:7px;background:#fff;color:#0f766e;font-weight:800;padding:0 14px}.sd-shell{border:1px solid #d8e3ec;background:#fff;box-shadow:0 18px 48px rgba(15,23,42,.08)}.sd-hero{min-height:220px;display:grid;grid-template-columns:122px minmax(0,1fr) minmax(420px,536px);gap:24px;align-items:center;padding:32px 26px;border-bottom:1px solid #dde7ef}.sd-logo{width:106px;height:106px;display:grid;place-items:center;overflow:hidden;border:1px solid #d8e6ee;border-radius:9px;background:#eef6f8}.sd-logo img{width:92px;height:92px;object-fit:contain}.sd-logo span{display:none;width:100%;height:100%;place-items:center;color:#0f766e;font-weight:900;font-size:28px}.sd-title{min-width:0}.sd-title h1{margin:0;color:#061229;font-size:42px;line-height:1.08;letter-spacing:0}.sd-title p{margin:10px 0 0;color:#51687f;font-size:18px}.sd-pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.sd-pill{display:inline-flex;align-items:center;min-height:26px;padding:3px 10px;border-radius:999px;background:#e9f3f4;color:#0f766e;font-size:13px;font-weight:800;white-space:nowrap}.sd-pill.blue{background:#eaf1ff;color:#2563eb}.sd-pill.rank{background:#fff1e7;color:#b45309}.sd-pill.muted{background:#eef2f7;color:#64748b}.sd-links{display:flex;flex-wrap:wrap;gap:14px 20px;margin-top:14px;color:#0f766e;font-size:15px}.sd-links a{color:#0f766e;text-decoration:none}.sd-links a:hover{text-decoration:underline}.sd-hero-metrics,.sd-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.sd-metric{min-height:106px;padding:20px 18px;border:1px solid #d8e3ec;border-radius:8px;background:#edf4f7}.sd-metric span{display:block;color:#536b83;font-size:15px}.sd-metric strong{display:block;margin-top:8px;color:#061229;font-size:30px;line-height:1.05;letter-spacing:0}.sd-tabs{display:flex;gap:22px;align-items:center;min-height:88px;padding:0 20px;border-bottom:1px solid #dde7ef;overflow-x:auto}.sd-tabs button{min-height:58px;border:0;border-bottom:3px solid transparent;background:transparent;color:#445b74;font-size:19px;font-weight:900;padding:0 16px;white-space:nowrap}.sd-tabs button.is-active{color:#0f766e;border-bottom-color:#0f766e}.sd-main{padding:20px}.sd-stat-grid{grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:18px}.sd-section,.sd-record-card,.sd-info,.sd-inner{border:1px solid #d8e3ec;border-radius:8px;background:#fff}.sd-section{padding:22px 24px;margin-bottom:18px}.sd-section h2,.sd-record-card h2{margin:0 0 14px;color:#061229;font-size:23px;line-height:1.2;letter-spacing:0}.sd-section h3,.sd-inner h3{margin:0 0 10px;color:#061229;font-size:18px}.sd-overview-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:24px}.sd-record-nav{position:sticky;top:16px;align-self:start;border:1px solid #d8e3ec;border-radius:8px;background:#fff;padding:14px}.sd-record-nav button{display:flex;align-items:center;gap:16px;width:100%;min-height:70px;border:1px solid transparent;border-radius:7px;background:transparent;color:#061229;font-size:20px;font-weight:900;text-align:left;padding:0 16px}.sd-record-nav button span{width:22px;color:#64748b;font-size:17px}.sd-record-nav button.is-active{border-color:#6793ff;background:#edf4ff;color:#2563eb}.sd-record-card{padding:26px}.sd-record-grid,.sd-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:14px}.sd-record-field{min-height:112px;padding:22px 20px;border-radius:8px;background:#eef3f6}.sd-record-field span,.sd-info span{display:block;color:#536b83;font-size:16px;font-weight:800}.sd-record-field strong,.sd-info strong{display:block;margin-top:8px;color:#061229;font-size:23px;line-height:1.32;white-space:pre-line}.sd-inner{margin-top:18px;padding:18px}.sd-copy{color:#1f2d3d;font-size:15px;line-height:1.74}.sd-copy p{margin:0 0 12px}.sd-copy h3{margin:18px 0 8px;font-size:18px;color:#0f172a}.sd-copy h4{margin:14px 0 8px;font-size:16px;color:#0f172a}.sd-copy ul,.sd-copy ol{margin:0 0 14px 22px;padding:0}.sd-copy li{margin:5px 0;padding-left:2px}.sd-copy strong{color:#061229;font-weight:900}.sd-copy code{padding:1px 5px;border-radius:5px;background:#eef3f6;color:#0f766e}.sd-copy a{color:#0f766e;text-decoration:none}.sd-copy a:hover{text-decoration:underline}.sd-copy hr{height:1px;border:0;background:#d8e3ec;margin:18px 0}.sd-md-table-wrap{overflow:auto;margin:8px 0 16px;border:1px solid #d8e3ec;border-radius:8px;background:#fff}.sd-md-table{width:100%;min-width:760px;border-collapse:collapse}.sd-md-table th,.sd-md-table td{padding:10px 12px;border-bottom:1px solid #e4ecf2;text-align:left;vertical-align:top;font-size:14px;line-height:1.55}.sd-md-table th{background:#eef4f7;color:#536b83;font-weight:900}.sd-md-table tr:last-child td{border-bottom:0}.sd-report-box{margin:18px 0 4px}.sd-report-box h3{margin:0 0 10px;color:#061229;font-size:18px}.sd-report-links{display:flex;flex-wrap:wrap;gap:8px}.sd-report-link{display:inline-flex;align-items:center;min-height:32px;padding:5px 10px;border-radius:999px;background:#e9f3f4;color:#0f766e;font-weight:800;text-decoration:none}.sd-report-link:hover{text-decoration:underline}.sd-policy-stack{display:grid;gap:18px}.sd-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sd-info{padding:18px;background:#eef3f6}.sd-filter-line{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;padding:14px 18px;border:1px solid #d8e3ec;border-radius:8px;background:#fff}.sd-filter-line label{display:flex;align-items:center;gap:10px;color:#536b83;font-weight:900}.sd-filter-line select{min-width:136px;border:1px solid #cddbe8;border-radius:7px;background:#fff;color:#061229;padding:8px 12px}.sd-filter-line span{color:#0f766e;font-weight:900}.sd-table-wrap{overflow:auto;border:1px solid #d8e3ec;border-radius:8px}.sd-table{width:100%;border-collapse:collapse;min-width:820px;background:#fff}.sd-table th,.sd-table td{padding:12px 14px;border-bottom:1px solid #e4ecf2;text-align:left;vertical-align:top;font-size:14px}.sd-table th{position:sticky;top:0;background:#eef4f7;color:#536b83;font-size:13px;z-index:1}.sd-table td strong{color:#061229}.sd-table td small{display:block;margin-top:4px;color:#64748b;line-height:1.35}.sd-empty,.sd-loading{min-height:180px;display:grid;place-items:center;border:1px dashed #cddbe8;border-radius:8px;background:#fff;color:#536b83;font-weight:800}.sd-loading{display:flex;justify-content:center;gap:10px}.sd-loading span{width:16px;height:16px;border-radius:50%;border:2px solid #cddbe8;border-top-color:#0f766e;animation:lbspin .8s linear infinite}
@media (max-width:980px){.sd-wrap{width:calc(100vw - 24px);margin:12px auto 36px}.sd-hero{grid-template-columns:80px minmax(0,1fr);gap:14px;padding:20px 16px}.sd-logo{width:72px;height:72px}.sd-logo img{width:62px;height:62px}.sd-title h1{font-size:32px}.sd-title p{font-size:14px}.sd-hero-metrics{grid-column:1/-1;grid-template-columns:repeat(3,minmax(0,1fr))}.sd-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sd-tabs{gap:8px;min-height:68px;padding:0 10px}.sd-tabs button{font-size:16px;min-height:48px;padding:0 10px}.sd-main{padding:12px}.sd-overview-layout{grid-template-columns:1fr}.sd-record-nav{position:static;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.sd-record-nav button{min-height:52px;font-size:15px}.sd-record-grid,.sd-info-grid{grid-template-columns:1fr}.sd-filter-line{align-items:flex-start;flex-direction:column}.sd-table{min-width:760px}}
@media (max-width:760px){.titlebar{top:20px}.titlebar h1{font-size:19px;letter-spacing:4px}.titlebar p{font-size:11px;max-width:94vw;overflow:hidden;text-overflow:ellipsis}.toolbar{display:none;top:62px}.cfgbtn{display:block}body.cfg-open .toolbar{display:flex}.searchbar{top:73px}.searchbox{height:40px}.botbar{bottom:12px;left:10px;right:10px;transform:none;display:grid;gap:8px;justify-items:center;max-width:none}.seg{max-width:calc(100vw - 22px);overflow-x:auto}.seg-i,.actbtn{font-size:12px;padding:8px 12px}.acts{max-width:calc(100vw - 22px);overflow-x:auto}.favbtn{right:12px;bottom:150px}.luckbtn{display:none}.panel,.rec-panel,.quiz-panel,.fav-panel,.stats-panel{left:10px;right:10px;top:auto;bottom:10px;width:auto;max-height:80dvh;transform:translateY(110%);border-radius:18px 18px 14px 14px}.panel.open,.fav-panel.open,.stats-panel.open{transform:translateY(0);opacity:1}.panel:before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:38px;height:4px;border-radius:2px;background:rgba(140,110,60,.32)}.detail-card{left:10px;right:10px;top:auto;bottom:148px;width:auto;transform:translateY(18px)}.detail-card.open{transform:none}.welcome.onboard{left:12px;right:12px;width:auto;transform:translate(0,-50%) scale(.96)}.welcome.onboard.show{transform:translate(0,-50%) scale(1)}.plabel{font-size:10px}.landmark-map{display:none}.umk .banner{font-size:10px}.bdg{width:18px;height:18px}.loadbar{top:102px;right:10px}.maplibregl-ctrl-top-right{display:none}.trow{grid-template-columns:72px 1fr}.tval{grid-column:2}}

/* School detail page: align with the scroll-map visual language while keeping long text readable. */
.school-detail-page{background:radial-gradient(circle at 12% 0,rgba(255,250,238,.86),transparent 34%),radial-gradient(circle at 86% 4%,rgba(189,154,85,.18),transparent 30%),linear-gradient(180deg,#f7f1e1 0%,#ece2c8 100%);color:var(--ink);font-family:var(--font-body)}
.school-detail-page:before{content:"";position:fixed;inset:0;pointer-events:none;opacity:.62;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='linear' slope='.055'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)'/%3E%3C/svg%3E");mix-blend-mode:multiply}
.sd-wrap{position:relative;z-index:1;width:min(1480px,calc(100vw - 48px));margin:18px auto 46px}
.sd-back{min-height:38px;border:1px solid var(--gold-soft);border-radius:999px;background:linear-gradient(180deg,var(--paper-a),var(--paper-b));color:var(--red);box-shadow:var(--elev);letter-spacing:1px}
.sd-shell{overflow:hidden;border:1px solid var(--gold-soft);border-radius:16px;background:linear-gradient(180deg,rgba(255,249,233,.96),rgba(246,232,202,.96));box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.sd-hero{position:relative;min-height:196px;grid-template-columns:112px minmax(0,1fr) minmax(320px,420px);gap:22px;padding:28px 28px 24px;border-bottom:1px solid rgba(189,154,85,.42);background:linear-gradient(135deg,rgba(255,253,246,.62),rgba(234,217,184,.5))}
.sd-hero:after{content:"";position:absolute;left:28px;right:28px;bottom:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.55}
.sd-logo{width:100px;height:100px;border-radius:50%;border:1px solid rgba(203,174,112,.82);background:#fff8e8;box-shadow:0 8px 20px rgba(63,45,23,.16)}
.sd-logo img{width:86px;height:86px;border-radius:50%;object-fit:contain}
.sd-title h1{color:var(--ink);font:700 42px/1.08 var(--font-display);letter-spacing:2px}
.sd-title p{margin-top:8px;color:var(--ink-soft);font-size:16px}
.sd-hero-note{max-width:820px;margin:12px 0 0;color:#5c4522;font-size:14px;line-height:1.7}
.sd-pill{min-height:27px;border:1px solid rgba(203,174,112,.42);background:rgba(255,252,242,.7);color:var(--ink-soft);font-size:12px}
.sd-pill.blue{background:rgba(156,47,27,.08);color:var(--red);border-color:rgba(156,47,27,.22)}
.sd-pill.rank{background:rgba(111,140,90,.13);color:#55723f;border-color:rgba(111,140,90,.22)}
.sd-pill.muted{background:rgba(234,217,184,.55);color:var(--muted)}
.sd-links{gap:10px 18px;color:var(--red);font-size:14px}
.sd-links a{color:var(--red)}
.sd-links span{color:var(--muted)}
.sd-hero-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.sd-metric{min-height:92px;padding:16px 15px;border:1px solid rgba(203,174,112,.58);border-radius:8px;background:rgba(255,253,246,.68);box-shadow:0 6px 18px rgba(63,45,23,.08)}
.sd-metric span{color:var(--muted);font-size:13px;font-weight:700}
.sd-metric strong{margin-top:7px;color:var(--red);font:800 27px/1.05 var(--font-body)}
.sd-tabs{min-height:72px;gap:10px;padding:0 18px;border-bottom:1px solid rgba(189,154,85,.38);background:rgba(255,248,229,.72)}
.sd-tabs button{min-height:48px;color:var(--ink-soft);font:700 16px/1 var(--font-display);letter-spacing:1px;padding:0 12px}
.sd-tabs button.is-active{color:var(--red);border-bottom-color:var(--red)}
.sd-main{padding:20px}
.sd-stat-grid{gap:12px;margin-bottom:16px}
.sd-section,.sd-record-card,.sd-info,.sd-inner{border:1px solid rgba(203,174,112,.58);border-radius:8px;background:rgba(255,253,246,.72);box-shadow:0 6px 18px rgba(63,45,23,.06)}
.sd-section{padding:20px 22px;margin-bottom:16px}
.sd-section h2,.sd-record-card h2{margin-bottom:14px;color:var(--ink);font:700 23px/1.2 var(--font-display);letter-spacing:1px}
.sd-section h3,.sd-inner h3{color:var(--ink);font-family:var(--font-display);letter-spacing:1px}
.sd-overview-layout{grid-template-columns:280px minmax(0,1fr);gap:18px}
.sd-record-nav{top:14px;border:1px solid rgba(203,174,112,.58);border-radius:8px;background:rgba(255,249,233,.82);box-shadow:0 8px 22px rgba(63,45,23,.08);padding:10px}
.sd-record-nav button{min-height:58px;border-radius:8px;color:var(--ink);font-size:16px;font-weight:800;padding:0 14px}
.sd-record-nav button span{color:var(--muted)}
.sd-record-nav button:hover{background:rgba(189,154,85,.13)}
.sd-record-nav button.is-active{border-color:rgba(156,47,27,.36);background:rgba(156,47,27,.08);color:var(--red)}
.sd-record-card{padding:24px 28px}
.sd-record-grid,.sd-info-grid{gap:12px;margin-bottom:12px}
.sd-record-field{min-height:88px;border:1px solid rgba(203,174,112,.28);border-radius:8px;background:rgba(255,248,229,.62);padding:16px}
.sd-record-field span,.sd-info span{color:var(--muted);font-size:13px}
.sd-record-field strong,.sd-info strong{color:var(--ink);font-size:19px}
.sd-inner{padding:18px 20px;margin-top:16px}
.sd-copy{max-width:960px;color:#3a2c1c;font-size:16px;line-height:1.9}
.sd-copy p{margin:0 0 13px}
.sd-copy h3{margin:22px 0 10px;padding-left:10px;border-left:3px solid var(--red);color:var(--red);font:700 20px/1.35 var(--font-display);letter-spacing:1px}
.sd-copy h4{margin:16px 0 8px;color:var(--ink);font:700 17px/1.35 var(--font-display);letter-spacing:1px}
.sd-copy ul,.sd-copy ol{margin:0 0 16px 22px}
.sd-copy li{margin:6px 0}
.sd-copy strong{color:#2f1d0d}
.sd-copy code{background:rgba(234,217,184,.68);color:var(--red)}
.sd-copy a{color:var(--red)}
.sd-copy hr{background:linear-gradient(90deg,transparent,rgba(189,154,85,.72),transparent);margin:20px 0}
.sd-md-table-wrap,.sd-table-wrap{border:1px solid rgba(203,174,112,.58);border-radius:8px;background:rgba(255,253,246,.86)}
.sd-md-table,.sd-table{background:rgba(255,253,246,.88)}
.sd-md-table th,.sd-table th{background:#ead9b8;color:#5f4721;font-weight:900}
.sd-md-table th,.sd-md-table td,.sd-table th,.sd-table td{border-bottom:1px solid rgba(203,174,112,.34)}
.sd-md-table tbody tr:nth-child(even),.sd-table tbody tr:nth-child(even){background:rgba(255,248,229,.42)}
.sd-report-box{padding:14px 16px;border:1px solid rgba(203,174,112,.4);border-radius:8px;background:rgba(255,248,229,.58)}
.sd-report-box h3{color:var(--ink);font-family:var(--font-display)}
.sd-report-link{border:1px solid rgba(156,47,27,.18);background:rgba(156,47,27,.08);color:var(--red)}
.sd-report-list{display:flex;flex-direction:column;gap:8px}
.sd-report-link{display:inline-flex;padding:10px 14px;border-radius:6px;font-size:14px;text-decoration:none;transition:background .15s}
.sd-report-link:hover{background:rgba(156,47,27,.16)}
.sd-acad-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.sd-acad-card{padding:14px 16px;border:1px solid rgba(203,174,112,.42);border-radius:8px;background:rgba(255,248,229,.52)}
.sd-acad-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.sd-acad-head strong{color:var(--ink);font-size:16px;font-family:var(--font-display);letter-spacing:1px}
.sd-acad-field{color:var(--muted);font-size:13px;line-height:1.55;margin:0;max-height:4.65em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.sd-info{border-radius:8px;background:rgba(255,248,229,.62)}
.sd-filter-line{border:1px solid rgba(203,174,112,.58);background:rgba(255,253,246,.72)}
.sd-filter-line label{color:var(--ink-soft)}
.sd-filter-line select{border-color:rgba(203,174,112,.72);background:#fff9ea;color:var(--ink)}
.sd-filter-line span{color:var(--red)}
.sd-empty,.sd-loading{border-color:rgba(203,174,112,.72);background:rgba(255,253,246,.72);color:var(--muted)}
@media (max-width:980px){.sd-wrap{width:calc(100vw - 24px);margin:12px auto 34px}.sd-hero{grid-template-columns:82px minmax(0,1fr);gap:14px;padding:20px 16px}.sd-logo{width:72px;height:72px}.sd-logo img{width:62px;height:62px}.sd-title h1{font-size:32px}.sd-hero-metrics{grid-column:1/-1}.sd-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.sd-overview-layout{grid-template-columns:1fr}.sd-record-nav{position:static;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.sd-record-card{padding:20px}.sd-copy{max-width:none;font-size:15px}.sd-md-table{min-width:720px}}
@media (max-width:760px){.sd-shell{border-radius:12px}.sd-title h1{font-size:29px;letter-spacing:1px}.sd-title p,.sd-hero-note{font-size:13px}.sd-tabs{min-height:62px;padding:0 8px}.sd-tabs button{font-size:14px;padding:0 8px}.sd-main{padding:12px}.sd-record-nav{grid-template-columns:1fr}.sd-record-nav button{min-height:48px}.sd-record-grid,.sd-info-grid{grid-template-columns:1fr}.sd-metric{min-height:78px;padding:13px}.sd-metric strong{font-size:23px}.sd-copy h3{font-size:18px}.sd-md-table,.sd-table{min-width:680px}}

/* School name label - shown when zoomed in, matches antique paper aesthetic */
.umk .sname {
  position: absolute;
  left: 50%;
  bottom: 100%;
  transform: translateX(-50%) translateY(-7px);
  opacity: 0;
  white-space: nowrap;
  transition: opacity 0.3s ease;
  z-index: 2;
}
.umk.show-name .sname {
  pointer-events: auto;
  cursor: pointer;
}
.umk .sname span {
  display: inline-block;
  background: linear-gradient(180deg, rgba(255,250,238,0.97), rgba(247,241,225,0.94));
  color: #3f2d17;
  padding: 3px 11px;
  border-radius: 5px;
  border: 1px solid rgba(190,160,100,0.32);
  box-shadow: 0 1px 6px rgba(63,45,20,0.10);
  font-weight: 700;
  font-size: 12px;
  font-family: var(--font-display, "Microsoft YaHei", "PingFang SC", serif);
  letter-spacing: 0.6px;
  line-height: 1.5;
}
.umk.show-name {
  pointer-events: auto !important;
  min-width: 40px;
  min-height: 18px;
}
.umk.show-name:before {
  content: '';
  position: absolute;
  top: -22px;
  left: -20px;
  right: -20px;
  bottom: -4px;
  pointer-events: auto;
}
.umk.show-name .sname {
  opacity: 1;
}
.umk.show-name .dot {
  background: #a05a30;
  border-color: rgba(255,250,240,0.95);
  box-shadow: 0 1px 4px rgba(80,45,20,0.40);
  transform: translate(-50%,50%) scale(1.15);
}
.umk.show-name:hover .sname span {
  background: linear-gradient(180deg, rgba(255,253,242,0.99), rgba(255,250,238,0.97));
  border-color: rgba(190,160,100,0.50);
  box-shadow: 0 2px 8px rgba(63,45,20,0.14);
}

/* Dot label for circle-marker schools (dotUnis) — antique paper style */
.dot-label {
  font-size: 11px;
  line-height: 1.35;
  pointer-events: auto;
  cursor: pointer;
  z-index: 6;
}
.dot-label span {
  display: inline-block;
  background: linear-gradient(180deg, rgba(255,250,238,0.97), rgba(247,241,225,0.94));
  color: #3f2d17;
  padding: 2px 8px;
  border-radius: 4px;
  border: 1px solid rgba(190,160,100,0.32);
  font-family: "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  box-shadow: 0 1px 4px rgba(63,45,23,0.10);
  white-space: nowrap;
}
.dot-label:hover span {
  background: linear-gradient(180deg, rgba(255,253,242,0.99), rgba(255,250,238,0.97));
  border-color: rgba(190,160,100,0.50);
  box-shadow: 0 2px 8px rgba(63,45,20,0.14);
}

/* Map hover tooltip — antique paper style */
.map-tooltip {
  position: absolute;
  pointer-events: none;
  z-index: 100;
  opacity: 0;
  transform: translate(-50%, -120%);
  transition: opacity 0.18s ease;
  white-space: nowrap;
}
.map-tooltip span {
  display: inline-block;
  background: linear-gradient(180deg, rgba(255,250,238,0.97), rgba(247,241,225,0.94));
  color: #3f2d17;
  padding: 3px 10px;
  border-radius: 4px;
  border: 1px solid rgba(190,160,100,0.35);
  font-family: "PingFang SC", "Microsoft YaHei", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.3px;
  box-shadow: 0 1px 5px rgba(63,45,23,0.13);
}
.map-tooltip.show {
  opacity: 1;
}
.map-tooltip::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid rgba(190,160,100,0.25);
}

/* School detail admission scores */
.sd-score-card {
  border: 1px solid rgba(203,174,112,.58);
  border-radius: 8px;
  background: rgba(255,253,246,.72);
  box-shadow: 0 6px 18px rgba(63,45,23,.06);
  padding: 20px 22px 22px;
}
.sd-score-tabs {
  display: flex;
  gap: 28px;
  align-items: center;
  border-bottom: 1px solid rgba(189,154,85,.38);
  margin-bottom: 18px;
}
.sd-score-tabs button {
  min-height: 52px;
  border: 0;
  border-bottom: 4px solid transparent;
  background: transparent;
  color: var(--ink);
  font: 800 22px/1 var(--font-display);
  letter-spacing: 1px;
  padding: 0 0 10px;
}
.sd-score-tabs button.is-active {
  color: #1d4ed8;
  border-bottom-color: #3152d4;
}
.sd-score-filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(220px, 326px));
  align-items: center;
  gap: 16px 28px;
  margin: 12px 0 18px;
}
.sd-score-filters label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-height: 56px;
  border: 1px solid rgba(203,174,112,.72);
  border-radius: 10px;
  background: rgba(255,252,242,.86);
  padding: 0 18px;
  color: var(--ink);
  font-size: 18px;
  font-weight: 800;
  white-space: nowrap;
}
.sd-score-filter-label {
  flex: 0 0 auto;
  color: #5d421d;
  font-weight: 900;
}
.sd-score-filters select {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-size: 18px;
  font-weight: 900;
  padding: 0;
  outline: 0;
}
.sd-score-meta {
  margin: 0 0 12px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}
.sd-score-table-wrap {
  max-height: none;
}
.sd-score-table {
  min-width: 1040px;
}
.sd-score-table th {
  font-size: 15px;
}
.sd-score-table td {
  font-size: 16px;
}
.sd-score-table td strong {
  color: #061229;
  font-weight: 900;
}
.sd-score-table td small {
  display: block;
  margin-top: 6px;
  color: #475569;
  font-size: 13px;
  line-height: 1.45;
}
@media (max-width:760px){
  .sd-score-card{padding:16px 14px}
  .sd-score-tabs{gap:18px;overflow-x:auto}
  .sd-score-tabs button{font-size:18px;white-space:nowrap}
  .sd-score-filters{grid-template-columns:1fr;gap:10px}
  .sd-score-filters select{min-width:0}
}
