*,:before,:after{box-sizing:border-box;margin:0;padding:0}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{box-sizing:content-box!important}:root{--accent:#0071e3;--accent-hover:#0077ed;--accent-light:#d1e8ff;--accent-bg:#0071e312;--accent-bg2:#0071e308;--green:#34c759;--green-bg:#34c75914;--orange:#ff9500;--orange-bg:#ff950014;--red:#ff3b30;--pink:#ff2d55;--purple:#af52de;--teal:#5ac8fa;--indigo:#5856d6;--mint:#00c7be;--bg:#f5f5f7;--bg2:#fff;--glass:#ffffffb8;--glass2:#ffffffd9;--card:#fff;--elevated:#fff;--border:#0000000f;--border-hover:#0000001f;--separator:#0000000a;--shadow-xs:0 .5px 1px #00000008;--shadow-sm:0 1px 3px #0000000a, 0 1px 2px #00000008;--shadow:0 4px 14px #0000000f, 0 1px 3px #0000000a;--shadow-lg:0 8px 28px #00000014, 0 2px 6px #0000000a;--shadow-xl:0 20px 50px #0000001a, 0 4px 12px #0000000a;--text:#1d1d1f;--text2:#3a3a3c;--text3:#636366;--text4:#8e8e93;--text5:#a1a1a6;--radius-sm:10px;--radius:14px;--radius-lg:20px;--radius-xl:24px}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;letter-spacing:-.01em;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,system-ui,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:15px;line-height:1.47}::selection{background:var(--accent-light);color:var(--accent)}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes bar-grow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes bar-grow-y{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001a;border-radius:100px}::-webkit-scrollbar-thumb:hover{background:#0000002e}.leaflet-container{border-radius:var(--radius-lg);background:var(--bg)!important}.leaflet-popup-content-wrapper{background:var(--card)!important;color:var(--text)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow-xl)!important;border:1px solid var(--border)!important}.leaflet-popup-tip{background:var(--card)!important}.leaflet-popup-content{margin:14px 18px!important;font-family:inherit!important;font-size:13px!important;line-height:1.5!important}.leaflet-popup-content div::-webkit-scrollbar{width:3px}.leaflet-popup-content div::-webkit-scrollbar-thumb{background:#0000001a;border-radius:100px}.leaflet-control-zoom{overflow:hidden;box-shadow:var(--shadow)!important;border-radius:var(--radius-sm)!important;border:none!important}.leaflet-control-zoom a{background:var(--card)!important;color:var(--text3)!important;border:none!important;border-bottom:1px solid var(--border)!important;width:34px!important;height:34px!important;font-size:16px!important;line-height:34px!important}.leaflet-control-zoom a:last-child{border-bottom:none!important}.leaflet-control-attribution{-webkit-backdrop-filter:blur(8px);background:var(--glass2)!important;color:var(--text4)!important;border-radius:4px!important;padding:2px 6px!important;font-size:9px!important}.leaflet-control-attribution a{color:var(--accent)!important}.app{max-width:1120px;margin:0 auto;padding:0 16px 16px}@media (min-width:768px){.app{padding:0 24px 24px}}.header{text-align:center;padding:48px 16px 8px;animation:.5s ease-out fadeUp}@media (min-width:768px){.header{padding:64px 20px 12px}}.header h1{color:var(--text);letter-spacing:-.8px;font-size:clamp(2rem,5.5vw,3rem);font-weight:800;line-height:1.08}.subtitle{color:var(--text3);margin-top:8px;font-size:15px;font-weight:400;line-height:1.6}@media (min-width:768px){.subtitle{font-size:17px}}.hl{color:var(--accent);font-weight:600}.quick-actions{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:16px;animation:.5s ease-out 50ms both fadeUp;display:flex}.quick-action{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-xs);color:var(--text2);cursor:pointer;white-space:nowrap;border-radius:100px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .25s;display:inline-flex}.quick-action:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover);transform:translateY(-1px)}.quick-action:active{transform:scale(.97)}.quick-action .qa-emoji{font-size:14px}.stats-bar{grid-template-columns:repeat(3,1fr);gap:8px;margin:24px 0 20px;animation:.5s ease-out 80ms both fadeUp;display:grid}@media (min-width:640px){.stats-bar{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-xs);padding:14px 10px;transition:all .3s}@media (min-width:768px){.stat-card{border-radius:18px;padding:18px 14px}}.stat-card:hover{box-shadow:var(--shadow);border-color:var(--border-hover);transform:translateY(-2px)}.stat-emoji{margin-bottom:2px;font-size:20px}.stat-number{color:var(--text);letter-spacing:-.4px;font-size:20px;font-weight:800;line-height:1.2}@media (min-width:768px){.stat-number{font-size:26px}}.stat-label{color:var(--text4);text-transform:uppercase;letter-spacing:.5px;margin-top:1px;font-size:10px;font-weight:600}.tab-bar-wrap{z-index:50;align-items:center;gap:0;margin:0 0 16px;animation:.5s ease-out .12s both fadeUp;display:flex;position:sticky;top:8px}.tab-bar{background:var(--glass);-webkit-backdrop-filter:saturate(180%)blur(20px);border:1px solid var(--border);min-width:0;box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-behavior:smooth;border-radius:12px;flex:1;gap:1px;padding:3px;display:flex;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,#000 100% 100%);mask-image:linear-gradient(90deg,#000 100% 100%)}.tab-bar.fade-left{-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 24px 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 24px 100%)}.tab-bar.fade-right{-webkit-mask-image:linear-gradient(90deg,#000 0% calc(100% - 24px),#0000 100%);mask-image:linear-gradient(90deg,#000 0% calc(100% - 24px),#0000 100%)}.tab-bar.fade-left.fade-right{-webkit-mask-image:linear-gradient(90deg,#0000 0%,#000 24px calc(100% - 24px),#0000 100%);mask-image:linear-gradient(90deg,#0000 0%,#000 24px calc(100% - 24px),#0000 100%)}.tab-bar::-webkit-scrollbar{display:none}.tab-arrow{background:var(--card);border:1px solid var(--border);width:28px;height:28px;box-shadow:var(--shadow-sm);color:var(--text3);cursor:pointer;z-index:2;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:inherit;font-size:16px;font-weight:600;transition:all .2s;display:none}.tab-arrow:hover{background:var(--bg);color:var(--accent);box-shadow:var(--shadow)}.tab-arrow:active{transform:scale(.92)}.tab-arrow-left{margin-right:-6px;display:flex}.tab-arrow-right{margin-left:-6px;display:flex}@media (max-width:767px){.tab-arrow{width:24px;height:24px;font-size:14px}.tab-arrow-left{margin-right:-4px}.tab-arrow-right{margin-left:-4px}}.tab-btn{color:var(--text3);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;flex-shrink:0;padding:8px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .2s}@media (min-width:768px){.tab-btn{padding:9px 18px;font-size:13px}}.tab-btn:hover{color:var(--text2)}.tab-btn:active{transform:scale(.97)}.tab-btn.active{background:var(--elevated);color:var(--text);font-weight:600;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a}.section-panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);margin-bottom:12px;padding:16px;animation:.4s ease-out fadeUp;overflow:hidden}@media (min-width:768px){.section-panel{padding:28px 32px}}.section-panel h2{color:var(--text);letter-spacing:-.3px;margin-bottom:2px;font-size:20px;font-weight:700}@media (min-width:768px){.section-panel h2{font-size:22px}}.section-subtitle{color:var(--text3);margin-bottom:20px;font-size:14px;line-height:1.5}.filters{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);margin-bottom:12px;padding:20px;animation:.4s ease-out fadeUp}@media (min-width:768px){.filters{padding:24px 28px}}.filters-title{color:var(--text);align-items:center;gap:8px;margin-bottom:16px;font-size:15px;font-weight:600;display:flex}.filter-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (min-width:480px){.filter-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:900px){.filter-grid{grid-template-columns:repeat(4,1fr)}}.filter-group label{color:var(--text4);letter-spacing:.2px;margin-bottom:5px;font-size:11px;font-weight:600;display:block}.filter-group select,.filter-group input[type=text]{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s}.filter-group select:focus,.filter-group input[type=text]:focus{border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px #0071e314}.filter-group select option{background:var(--card)}.search-hints{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.search-hint{color:var(--text4);background:var(--bg);cursor:pointer;border:1px solid var(--border);border-radius:100px;padding:4px 10px;font-family:inherit;font-size:11px;font-weight:500;transition:all .2s}.search-hint:hover{background:var(--accent-bg);color:var(--accent);border-color:#0071e326}.searchable-select{width:100%;position:relative}.ss-trigger{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);cursor:pointer;text-align:left;outline:none;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-family:inherit;font-size:14px;transition:all .2s;display:flex}.ss-trigger:hover{border-color:var(--border-hover)}.ss-trigger-text{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.ss-arrow{color:var(--text4);font-size:10px}.ss-dropdown{background:var(--elevated);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xl);z-index:100;animation:.15s ease-out scaleIn;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden}.ss-search{border:none;border-bottom:1px solid var(--separator);width:100%;color:var(--text);background:0 0;outline:none;padding:12px 16px;font-family:inherit;font-size:14px}.ss-search::placeholder{color:var(--text5)}.ss-options{max-height:240px;padding:4px;overflow-y:auto}.ss-option{border-radius:var(--radius-sm);width:100%;color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;font-family:inherit;font-size:14px;transition:background .12s;display:flex}.ss-option:hover{background:var(--bg)}.ss-option.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.ss-option-count{color:var(--text5);background:var(--bg);border-radius:6px;padding:2px 8px;font-size:11px;font-weight:500}.ss-empty{text-align:center;color:var(--text4);padding:20px;font-size:14px}.chip-section-label{color:var(--text4);letter-spacing:.2px;margin:14px 0 8px;font-size:11px;font-weight:600;display:block}.chip-row{flex-wrap:wrap;gap:6px;display:flex}.chip{cursor:pointer;border:1px solid var(--border);-webkit-user-select:none;user-select:none;background:var(--card);color:var(--text3);box-shadow:var(--shadow-xs);border-radius:100px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.chip:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.chip:active{transform:scale(.96)}.chip.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent);font-weight:600}.chip-ppm.active,.chip-pkc.active,.chip-pgft.active,.chip-pre.active,.chip-prsh.active,.chip-pvgk.active,.chip-pai.active,.chip-pki.active{border-color:var(--accent);background:var(--accent-bg);color:var(--accent)}.chip-pimnas{color:#e08600}.chip-pimnas.active{background:var(--orange-bg);border-color:var(--orange);color:#c27400}.range-input{-webkit-appearance:none;appearance:none;background:var(--border);cursor:pointer;border-radius:100px;outline:none;flex:1;height:4px}.range-input::-webkit-slider-thumb{-webkit-appearance:none;background:var(--card);border:2px solid var(--accent);width:20px;height:20px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:50%;transition:all .2s}.range-input::-webkit-slider-thumb:hover{box-shadow:var(--shadow);transform:scale(1.1)}.analytics-grid{grid-template-columns:1fr;gap:10px;display:grid}@media (min-width:700px){.analytics-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:12px}}.analytics-card{background:var(--bg);border:1px solid var(--separator);border-radius:var(--radius);padding:16px;transition:all .25s;overflow:hidden}@media (min-width:768px){.analytics-card{padding:20px}}.analytics-card:hover{box-shadow:var(--shadow-sm);border-color:var(--border)}.analytics-card h3{color:var(--text2);letter-spacing:-.1px;margin-bottom:14px;font-size:13px;font-weight:700}.analytics-card.wide{grid-column:1/-1}.h-bar-item{align-items:center;gap:8px;padding:4px 0;display:flex}.h-bar-label{color:var(--text3);text-overflow:ellipsis;white-space:nowrap;flex:none;max-width:35%;font-size:11px;overflow:hidden}@media (min-width:768px){.h-bar-label{max-width:38%;font-size:12px}}.h-bar-track{background:var(--separator);border-radius:100px;flex:1;height:6px;overflow:hidden}.h-bar-fill{transform-origin:0;border-radius:100px;height:100%;animation:.6s ease-out both bar-grow}.h-bar-value{text-align:right;min-width:24px;color:var(--text2);font-size:12px;font-weight:700}.v-chart{align-items:flex-end;gap:4px;height:120px;display:flex}@media (min-width:768px){.v-chart{gap:6px;height:150px}}.v-bar-wrap{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.v-bar{transform-origin:bottom;border-radius:5px 5px 2px 2px;width:100%;max-width:28px;min-height:3px;animation:.5s ease-out both bar-grow-y}.v-bar-count{color:var(--text3);margin-bottom:2px;font-size:9px;font-weight:700}.v-bar-label{color:var(--text4);margin-top:4px;font-size:9px}.donut-row{flex-wrap:wrap;gap:6px;display:flex}.donut-item{background:var(--card);border:1px solid var(--separator);border-radius:12px;flex:100%;align-items:center;gap:10px;min-width:0;padding:10px 14px;transition:all .2s;display:flex}@media (min-width:480px){.donut-item{flex:calc(50% - 3px)}}.donut-item:hover{box-shadow:var(--shadow-xs);border-color:var(--border)}.donut-ring{border-radius:50%;flex-shrink:0;width:40px;height:40px;position:relative}.donut-ring svg{width:40px;height:40px;transform:rotate(-90deg)}.donut-ring circle{fill:none;stroke-width:4px;stroke-linecap:round}.donut-ring .bg{stroke:var(--separator)}.donut-ring .fg{transition:stroke-dashoffset .8s ease-out}.donut-pct{justify-content:center;align-items:center;font-size:9px;font-weight:800;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.donut-info{min-width:0}.donut-info .name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}@media (min-width:768px){.donut-info .name{font-size:13px}}.donut-info .sub{color:var(--text4);font-size:11px}.stat-row{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}@media (min-width:480px){.stat-row{grid-template-columns:repeat(4,1fr)}}.mini-stat{background:var(--card);text-align:center;border:1px solid var(--separator);border-radius:12px;padding:12px 8px;transition:all .2s}.mini-stat:hover{box-shadow:var(--shadow-xs)}.mini-stat .val{color:var(--text);letter-spacing:-.3px;word-break:break-all;font-size:16px;font-weight:800;line-height:1.2}@media (min-width:768px){.mini-stat .val{font-size:22px}}.mini-stat .lbl{color:var(--text4);text-transform:uppercase;letter-spacing:.2px;text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:8px;font-weight:600;overflow:hidden}@media (min-width:768px){.mini-stat .lbl{font-size:9px}}.heatmap-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.heatmap-cell{aspect-ratio:1;color:#fff;border-radius:4px;justify-content:center;align-items:center;min-width:24px;font-size:10px;font-weight:700;display:flex}.heatmap-header{color:var(--text4);justify-content:center;align-items:center;min-width:24px;font-size:10px;font-weight:600;display:flex}.pattern-item{border-bottom:1px solid var(--separator);align-items:center;gap:8px;padding:8px 0;display:flex;overflow:hidden}.pattern-item:last-child{border-bottom:none}.pattern-icon{flex-shrink:0;font-size:18px}.pattern-info{flex:1;min-width:0}.pattern-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.pattern-desc{color:var(--text4);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}@media (min-width:768px){.pattern-name{font-size:13px}.pattern-desc{font-size:11px}}.pattern-bar-wrap{background:var(--separator);border-radius:100px;flex-shrink:0;width:60px;height:4px;overflow:hidden}@media (min-width:768px){.pattern-bar-wrap{width:80px}}.pattern-bar-fill{transform-origin:0;border-radius:100px;height:100%;animation:.5s ease-out both bar-grow}.pattern-count{text-align:right;min-width:28px;color:var(--text2);font-size:12px;font-weight:700}.results-header{justify-content:space-between;align-items:center;margin:4px 0 10px;display:flex}.results-header h2{color:var(--text);align-items:center;gap:6px;font-size:15px;font-weight:700;display:flex}.results-count{background:var(--accent-bg);color:var(--accent);border-radius:100px;padding:4px 12px;font-size:12px;font-weight:600}.results-grid{gap:8px;display:grid}.result-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:16px;padding:16px 18px;transition:all .25s;animation:.3s ease-out both slideRight}@media (min-width:768px){.result-card{padding:18px 22px}}.result-card:hover{box-shadow:var(--shadow);border-color:var(--border-hover)}.result-card .title{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:600;line-height:1.55}.result-meta{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.meta-tag{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600}.meta-year{background:var(--accent-bg);color:var(--accent)}.meta-skim{color:var(--indigo);background:#5856d612}.meta-pimnas{background:var(--orange-bg);color:#c27400}.meta-dana{background:var(--green-bg);color:#1d8a38}.result-details{color:var(--text4);font-size:12px;line-height:1.6}.result-details span{display:block}.search-match{color:var(--accent);background:#0071e31a;border-radius:3px;padding:0 2px}.keyword-cloud{flex-wrap:wrap;gap:6px;margin-top:14px;display:flex}.keyword{cursor:pointer;border:1px solid var(--border);background:var(--card);box-shadow:var(--shadow-xs);border-radius:100px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.keyword:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover);transform:translateY(-1px)}.keyword:active{transform:scale(.97)}.tip-box{background:var(--bg);border-left:3px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;color:var(--text2);margin:8px 0;padding:16px 18px;font-size:14px;line-height:1.65;transition:all .25s}@media (min-width:768px){.tip-box{padding:18px 22px}}.tip-box:hover{background:var(--accent-bg2);box-shadow:var(--shadow-xs)}.tip-box strong{color:var(--accent)}.tip-number{background:var(--accent);color:#fff;border-radius:7px;justify-content:center;align-items:center;width:22px;height:22px;margin-right:6px;font-size:11px;font-weight:800;display:inline-flex}.pagination{flex-wrap:wrap;justify-content:center;gap:4px;margin:20px 0;display:flex}.page-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--text2);cursor:pointer;text-align:center;min-width:38px;box-shadow:var(--shadow-xs);padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s}.page-btn:hover{box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.page-btn:active{transform:scale(.96)}.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #0071e333}.page-btn:disabled{opacity:.3;cursor:not-allowed}.map-container{border-radius:var(--radius-lg);border:1px solid var(--border);height:320px;box-shadow:var(--shadow);margin-bottom:12px;position:relative;overflow:hidden}@media (min-width:768px){.map-container{height:420px}}.map-container .leaflet-container{width:100%!important;height:100%!important}.map-hint{background:var(--glass2);-webkit-backdrop-filter:blur(10px);color:var(--text3);z-index:10;pointer-events:none;border:1px solid var(--border);white-space:nowrap;border-radius:100px;padding:6px 14px;font-size:11px;font-weight:500;animation:.5s ease-out .5s both fadeUp;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}@media (min-width:768px){.map-hint{display:none}}.city-leaderboard{grid-template-columns:1fr;gap:4px;display:grid}@media (min-width:480px){.city-leaderboard{grid-template-columns:repeat(2,1fr)}}@media (min-width:900px){.city-leaderboard{grid-template-columns:repeat(3,1fr)}}.city-card{background:var(--bg);border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:8px;padding:10px 12px;transition:all .2s;display:flex}.city-card:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}.city-rank{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:800;display:inline-flex}.city-info{flex:1;min-width:0}.city-name{color:var(--text);font-size:13px;font-weight:600}.city-sub{color:var(--text4);font-size:11px}.city-bar{background:var(--separator);border-radius:100px;flex-shrink:0;width:50px;height:4px;overflow:hidden}.city-bar-fill{transform-origin:0;border-radius:100px;height:100%;animation:.5s ease-out both bar-grow}.city-count{text-align:right;min-width:20px;color:var(--text2);font-size:12px;font-weight:700}.dana-range-bar{background:var(--bg);border:1px solid var(--separator);border-radius:8px;height:24px;margin:10px 0 6px;position:relative;overflow:hidden}.dana-range-fill{opacity:.1;background:linear-gradient(90deg,#34c759,#5ac8fa,#0071e3);position:absolute;top:0;bottom:0;left:0;right:0}.dana-range-marker{background:var(--orange);border-radius:2px;width:3px;position:absolute;top:-2px;bottom:-2px;box-shadow:0 0 6px #ff95004d}.dana-labels{color:var(--text4);justify-content:space-between;font-size:11px;font-weight:500;display:flex}.histogram{align-items:flex-end;gap:2px;height:70px;display:flex}@media (min-width:768px){.histogram{height:80px}}.hist-bar{transform-origin:bottom;cursor:default;border-radius:3px 3px 0 0;flex:1;min-width:4px;transition:opacity .2s;animation:.4s ease-out both bar-grow-y}.hist-bar:hover{opacity:.65}.hist-labels{color:var(--text4);justify-content:space-between;margin-top:3px;font-size:10px;display:flex}.save-btn{cursor:pointer;opacity:.3;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:4px;font-size:18px;line-height:1;transition:all .2s}.save-btn:hover{opacity:1;transform:scale(1.15)}.result-card:hover .save-btn{opacity:.6}.note-input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:12px;outline:none;flex:1;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .2s}.note-input:focus{border-color:var(--accent);background:var(--card);box-shadow:0 0 0 3px #0071e314}.note-add-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:44px;font-size:20px;font-weight:500;transition:all .2s}.note-add-btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #0071e333}.note-add-btn:active{transform:scale(.95)}.note-card{background:var(--bg);border:1px solid var(--separator);border-radius:var(--radius);margin-bottom:8px;padding:14px 16px;transition:all .2s}.note-card:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}.note-text{color:var(--text);font-size:14px;line-height:1.55}.note-meta{color:var(--text4);justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;display:flex}.note-delete{color:var(--red);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:3px 10px;font-family:inherit;font-size:11px;font-weight:600;transition:all .2s}.note-delete:hover{background:#ff3b300f}.note-analysis{border-top:1px solid var(--separator);margin-top:12px;padding-top:12px}.example-note{background:var(--bg);border:1px dashed var(--border);border-radius:var(--radius);padding:18px 20px;animation:.4s ease-out fadeUp}.saved-card{background:var(--bg);border:1px solid var(--separator);border-radius:16px;margin-bottom:8px;padding:16px;transition:all .2s}.saved-card:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}.saved-card.checked{opacity:.45}.check-btn{cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:2px;font-size:18px;transition:transform .15s}.check-btn:hover{transform:scale(1.15)}.remove-btn{color:var(--text5);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:4px 8px;font-size:14px;transition:all .2s}.remove-btn:hover{color:var(--red);background:#ff3b300d}.insight-pill{background:var(--bg);color:var(--text3);border:1px solid var(--separator);border-radius:8px;padding:3px 9px;font-size:11px;font-weight:500;line-height:1.4;display:inline-block}.insight-pill.good{background:var(--green-bg);color:#1d8a38;border-color:#34c75926}.insight-pill.warn{background:var(--orange-bg);color:#c27400;border-color:#ff950026}.insight-pill.tip{background:var(--accent-bg);color:var(--accent);border-color:#0071e31a}.expand-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:10px;padding:4px 0;font-family:inherit;font-size:12px;font-weight:600;transition:opacity .2s;display:inline-block}.expand-btn:hover{opacity:.7}.insight-expand{border-top:1px solid var(--separator);margin-top:14px;padding-top:14px;animation:.3s ease-out fadeUp}.insight-grid-sm{grid-template-columns:1fr;gap:8px;display:grid}@media (min-width:600px){.insight-grid-sm{grid-template-columns:repeat(3,1fr)}}.insight-box{background:var(--card);border:1px solid var(--separator);border-radius:12px;padding:14px}.insight-box-title{color:var(--text2);margin-bottom:8px;font-size:12px;font-weight:700}.insight-row{border-bottom:1px solid var(--separator);justify-content:space-between;align-items:center;padding:4px 0;font-size:12px;display:flex}.insight-row:last-child{border-bottom:none}.insight-row span{color:var(--text3)}.insight-row strong{color:var(--text)}.similar-card{background:var(--card);border:1px solid var(--separator);border-radius:var(--radius-sm);margin-bottom:6px;padding:10px 12px;transition:box-shadow .2s}.similar-card:hover{box-shadow:var(--shadow-xs)}.score-ring{background:conic-gradient(var(--accent) calc(var(--pct) * 1%), var(--separator) calc(var(--pct) * 1%));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex;position:relative}.score-ring:before{content:"";background:var(--bg);border-radius:50%;position:absolute;top:4px;bottom:4px;left:4px;right:4px}.score-ring span{color:var(--accent);font-size:12px;font-weight:800;position:relative}.no-results{text-align:center;color:var(--text3);padding:48px 16px;animation:.4s ease-out fadeUp}.no-results .big-emoji{margin-bottom:8px;font-size:40px}.loading{text-align:center;color:var(--text3);padding:48px 16px;font-size:14px}.loading-spinner{border:3px solid var(--separator);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;margin:0 auto 14px;animation:.7s linear infinite spin}@keyframes skeleton-shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.skeleton-stats{grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;display:grid}@media (min-width:640px){.skeleton-stats{grid-template-columns:repeat(6,1fr)}}.skeleton-stat{background:linear-gradient(90deg, var(--bg) 25%, #0000000a 37%, var(--bg) 63%);background-size:200px 100%;border-radius:14px;height:72px;animation:1.4s infinite skeleton-shimmer}.skeleton-bar{background:linear-gradient(90deg, var(--bg) 25%, #0000000a 37%, var(--bg) 63%);background-size:200px 100%;border-radius:12px;height:42px;margin-bottom:12px;animation:1.4s infinite skeleton-shimmer}.skeleton-card{background:var(--card);border:1px solid var(--border);border-radius:16px;margin-bottom:8px;padding:18px}.skeleton-line{background:linear-gradient(90deg, var(--bg) 25%, #0000000a 37%, var(--bg) 63%);background-size:200px 100%;border-radius:6px;height:12px;margin-bottom:8px;animation:1.4s infinite skeleton-shimmer}.skeleton-line:last-child{margin-bottom:0}.skeleton-line.w40{width:40%}.skeleton-line.w70{width:70%}.skeleton-line.w100{width:100%}.footer{text-align:center;color:var(--text4);padding:32px 16px;font-size:12px}.soul-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg,#0071e30a,#5ac8fa0a);border:1px solid #0071e31a;align-items:flex-start;gap:14px;margin-bottom:16px;padding:18px 20px;animation:.5s ease-out .16s both fadeUp;display:flex;position:relative}.soul-icon{background:var(--card);border:1px solid var(--border);width:44px;height:44px;box-shadow:var(--shadow-xs);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;font-size:22px;display:flex}.soul-body{flex:1;min-width:0}.soul-title{color:var(--text);margin-bottom:2px;font-size:14px;font-weight:700}.soul-desc{color:var(--text3);margin-bottom:10px;font-size:13px;line-height:1.55}.soul-action{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:100px;align-items:center;gap:4px;padding:7px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 2px 8px #0071e333}.soul-action:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0071e34d}.soul-action:active{transform:scale(.97)}.soul-input-row{gap:6px;animation:.2s ease-out fadeIn;display:flex}.soul-input{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:10px;outline:none;flex:1;min-width:0;padding:8px 14px;font-family:inherit;font-size:13px;transition:border-color .2s}.soul-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e314}.soul-go{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;padding:8px 16px;font-family:inherit;font-size:12px;font-weight:600;transition:all .2s}.soul-go:hover{box-shadow:0 2px 8px #0071e333}.soul-go:active{transform:scale(.97)}.soul-next{cursor:pointer;width:28px;height:28px;color:var(--text4);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:14px;transition:all .2s;display:flex;position:absolute;top:10px;right:10px}.soul-next:hover{background:var(--bg);color:var(--accent)}@media (max-width:480px){.soul-banner{gap:10px;padding:14px 16px}.soul-icon{border-radius:12px;width:38px;height:38px;font-size:18px}.soul-title{font-size:13px}.soul-desc{font-size:12px}}.pimo-tip{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-xs);border-radius:16px;align-items:flex-start;gap:12px;margin-bottom:12px;padding:14px 18px;animation:.35s ease-out fadeUp;display:flex;position:relative}.pimo-avatar{width:36px;height:36px;box-shadow:var(--shadow-xs);background:linear-gradient(135deg,#ffecd2,#fcb69f);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;display:flex}.pimo-body{flex:1;min-width:0}.pimo-name{color:var(--text);align-items:center;gap:6px;margin-bottom:2px;font-size:12px;font-weight:700;display:flex}.pimo-badge{color:var(--accent);background:var(--accent-bg);letter-spacing:.3px;text-transform:uppercase;border-radius:6px;padding:1px 6px;font-size:9px;font-weight:700}.pimo-msg{color:var(--text2);font-size:13px;line-height:1.55}.pimo-actions{flex-shrink:0;align-self:flex-start;gap:4px;display:flex}.pimo-next,.pimo-dismiss{cursor:pointer;width:26px;height:26px;color:var(--text4);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-family:inherit;font-size:12px;transition:all .2s;display:flex}.pimo-next:hover{background:var(--bg);color:var(--accent)}.pimo-dismiss:hover{color:var(--red);background:#ff3b300f}@media (max-width:480px){.pimo-tip{gap:10px;padding:12px 14px}.pimo-avatar{border-radius:10px;width:32px;height:32px;font-size:16px}.pimo-msg{font-size:12px}}.resource-category{margin-bottom:6px}.resource-cat-header{background:var(--bg);border:1px solid var(--separator);border-radius:var(--radius);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:14px 18px;font-family:inherit;transition:all .2s;display:flex}.resource-cat-header:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}.resource-cat-title{color:var(--text);font-size:14px;font-weight:700}.resource-cat-desc{color:var(--text4);margin-top:1px;font-size:12px}.resource-cat-count{color:var(--accent);background:var(--accent-bg);border-radius:100px;padding:2px 8px;font-size:11px;font-weight:600}.resource-cat-arrow{color:var(--text4);font-size:10px;transition:transform .2s}.resource-list{gap:6px;padding:8px 0 4px;animation:.25s ease-out fadeUp;display:grid}@media (min-width:640px){.resource-list{grid-template-columns:repeat(2,1fr)}}.resource-card{background:var(--card);border:1px solid var(--separator);color:inherit;border-radius:12px;align-items:flex-start;gap:12px;padding:14px 16px;text-decoration:none;transition:all .25s;display:flex}.resource-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.resource-card-main{flex:1;min-width:0}.resource-name{color:var(--text);margin-bottom:3px;font-size:13px;font-weight:700}.resource-card:hover .resource-name{color:var(--accent)}.resource-desc{color:var(--text3);font-size:12px;line-height:1.5}.resource-tags{flex-wrap:wrap;gap:3px;margin-top:8px;display:flex}.resource-tag{background:var(--bg);color:var(--text4);border:1px solid var(--separator);border-radius:6px;padding:2px 7px;font-size:10px;font-weight:600}.resource-arrow{color:var(--text5);flex-shrink:0;margin-top:2px;font-size:14px;transition:all .2s}.resource-card:hover .resource-arrow{color:var(--accent);transform:translate(2px,-2px)}.pimo-live{z-index:9999;-webkit-user-select:none;user-select:none;touch-action:none;filter:drop-shadow(0 2px 6px #0000001f);pointer-events:auto;position:fixed}.pimo-char{justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.pimo-face{font-size:36px;line-height:1;transition:transform .15s}.pimo-live:active .pimo-face{transform:scale(1.15)}.pimo-zzz{font-size:16px;animation:2s ease-in-out infinite zzz-float;position:absolute;top:-12px;right:-8px}@keyframes zzz-float{0%,to{opacity:.7;transform:translateY(0)scale(1)}50%{opacity:1;transform:translateY(-10px)scale(1.1)}}.pimo-shadow{background:#00000014;border-radius:50%;width:30px;height:6px;margin:-4px auto 0;transition:all .3s}.pimo-nametag{text-align:center;color:var(--text4);letter-spacing:.3px;margin-top:1px;font-size:9px;font-weight:700}.pimo-speech-fixed{z-index:10000;background:var(--card);border:1px solid var(--border);color:var(--text2);box-shadow:var(--shadow-lg);white-space:normal;text-align:center;pointer-events:none;border-radius:12px;min-width:80px;max-width:220px;padding:8px 14px;font-size:12px;font-weight:500;line-height:1.45;animation:.25s cubic-bezier(.34,1.56,.64,1) speech-pop;position:fixed;transform:translateY(-100%)}.pimo-speech-fixed.pimo-arrow-bottom:after{content:"";top:100%;left:clamp(12px, var(--arrow-left,50%), calc(100% - 12px));border:5px solid #0000;border-top-color:var(--card);margin-left:-5px;position:absolute}.pimo-speech-fixed.pimo-arrow-top{transform:translateY(0)}.pimo-speech-fixed.pimo-arrow-top:after{content:"";bottom:100%;left:clamp(12px, var(--arrow-left,50%), calc(100% - 12px));border:5px solid #0000;border-bottom-color:var(--card);margin-left:-5px;position:absolute}@keyframes speech-pop{0%{opacity:0;transform:translateY(-100%)scale(.85)}to{opacity:1;transform:translateY(-100%)scale(1)}}.pimo-arrow-top{animation-name:speech-pop-down}@keyframes speech-pop-down{0%{opacity:0;transform:translateY(0)scale(.85)}to{opacity:1;transform:translateY(0)scale(1)}}.pimo-idle .pimo-char{animation:3s ease-in-out infinite pimo-breathe}@keyframes pimo-breathe{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.pimo-walk .pimo-char{animation:.3s ease-in-out infinite pimo-bob}@keyframes pimo-bob{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-5px)rotate(-3deg)}75%{transform:translateY(-5px)rotate(3deg)}}.pimo-walk .pimo-shadow{animation:.3s ease-in-out infinite shadow-walk}@keyframes shadow-walk{0%,to{opacity:.08;transform:scaleX(1)}50%{opacity:.04;transform:scaleX(.7)}}.pimo-sit .pimo-char{animation:2s ease-in-out infinite pimo-sit-bob;transform:translateY(4px)}@keyframes pimo-sit-bob{0%,to{transform:translateY(4px)}50%{transform:translateY(2px)}}.pimo-sit .pimo-shadow{transform:scaleX(1.2)}.pimo-sleep .pimo-char{animation:3s ease-in-out infinite pimo-sleep-bob;transform:translateY(4px)}@keyframes pimo-sleep-bob{0%,to{transform:translateY(4px)rotate(-5deg)}50%{transform:translateY(2px)rotate(-5deg)}}.pimo-bounce .pimo-char{animation:.5s cubic-bezier(.34,1.56,.64,1) pimo-bounce-anim}@keyframes pimo-bounce-anim{0%{transform:scale(1)}30%{transform:scale(1.3)translateY(-16px)}50%{transform:scale(.85)translateY(0)}70%{transform:scale(1.08)translateY(-5px)}to{transform:scale(1)translateY(0)}}.pimo-run .pimo-char{animation:.18s ease-in-out infinite pimo-run-bob}@keyframes pimo-run-bob{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-8px)rotate(-6deg)}75%{transform:translateY(-8px)rotate(6deg)}}.pimo-run .pimo-shadow{animation:.18s ease-in-out infinite shadow-run}@keyframes shadow-run{0%,to{opacity:.06;transform:scaleX(1)}50%{opacity:.02;transform:scaleX(.5)}}.pimo-dance .pimo-char{animation:.4s ease-in-out infinite pimo-dance-anim}@keyframes pimo-dance-anim{0%{transform:translateY(0)rotate(0)scale(1)}25%{transform:translateY(-10px)rotate(-12deg)scale(1.05)}50%{transform:translateY(0)rotate(0)scale(1)}75%{transform:translateY(-10px)rotate(12deg)scale(1.05)}to{transform:translateY(0)rotate(0)scale(1)}}.pimo-dust{opacity:.6;font-size:14px;animation:.4s ease-out infinite dust-fade;position:absolute;bottom:0;right:-8px}@keyframes dust-fade{0%{opacity:.6;transform:translate(0)scale(1)}to{opacity:0;transform:translate(10px)scale(.5)}}.pimo-note{font-size:12px;animation:1.2s ease-out infinite note-float;position:absolute}.pimo-note.n1{animation-delay:0s;top:-8px;right:-6px}.pimo-note.n2{animation-delay:.5s;top:-4px;left:-6px}@keyframes note-float{0%{opacity:.8;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-24px)translate(8px)scale(.5)rotate(20deg)}}.pimo-hearts{font-size:14px;animation:1s ease-out infinite hearts-float;position:absolute;top:-14px;right:-6px}@keyframes hearts-float{0%{opacity:.9;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-20px)scale(.6)}}@media (max-width:380px){.pimo-live{display:none}}.tab-highlight{color:var(--accent)!important;font-weight:600!important}.tab-highlight.active{background:var(--accent)!important;color:#fff!important}.swipe-card{background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);touch-action:none;cursor:grab;-webkit-user-select:none;user-select:none;border-radius:20px;max-width:540px;margin:0 auto;padding:24px;position:relative;overflow:hidden}.swipe-card.dragging{cursor:grabbing;transition:none!important}.swipe-card:not(.dragging){transition:transform .35s,opacity .35s}.swipe-card.swipe-right{opacity:0;transform:translate(120%)rotate(12deg)}.swipe-card.swipe-left{opacity:0;transform:translate(-120%)rotate(-12deg)}.swipe-overlay{z-index:2;opacity:0;pointer-events:none;border:3px solid;border-radius:12px;padding:8px 18px;font-size:16px;font-weight:800;transition:opacity .15s;position:absolute;top:16px}.swipe-overlay-save{color:var(--green);border-color:var(--green);background:#34c75914;right:16px}.swipe-overlay-skip{color:var(--red);border-color:var(--red);background:#ff3b3014;left:16px}.swipe-already-saved{color:var(--orange);background:var(--orange-bg);border-radius:100px;padding:3px 10px;font-size:11px;font-weight:600;position:absolute;top:12px;right:12px}.swipe-actions{justify-content:center;gap:12px;margin-top:20px;display:flex}.swipe-btn{border:2px solid var(--border);background:var(--card);cursor:pointer;width:72px;height:72px;box-shadow:var(--shadow-sm);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-family:inherit;font-size:24px;transition:all .2s;display:flex}.swipe-btn:active{transform:scale(.9)}.swipe-btn-label{color:var(--text4);font-size:10px;font-weight:600}.swipe-skip{border-color:#ff3b3033}.swipe-skip:hover{border-color:var(--red);box-shadow:var(--shadow);background:#ff3b300a}.swipe-save{border-color:#34c75933}.swipe-save:hover{border-color:var(--green);box-shadow:var(--shadow);background:#34c7590a}.lb-item{cursor:pointer;border:1px solid #0000;border-radius:12px;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:4px;padding:12px 14px;transition:all .2s;display:flex}.lb-item:hover{background:var(--bg);border-color:var(--border)}.lb-rank{border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:800;display:flex}.lb-info{flex:1;min-width:0}.lb-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.lb-sub{color:var(--text4);margin-top:1px;font-size:11px}.lb-stats{flex-shrink:0}.lb-badge{color:var(--accent);background:var(--accent-bg);border-radius:100px;padding:3px 10px;font-size:12px;font-weight:700}.lb-expand{border-top:1px solid var(--separator);width:100%;margin-top:8px;padding:12px 0 0;animation:.25s ease-out fadeUp;overflow:hidden}.lb-expand-grid{grid-template-columns:repeat(2,1fr);gap:6px;display:grid}@media (min-width:480px){.lb-expand-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:480px){.lb-name{font-size:12px}.lb-sub{font-size:10px}.lb-badge{padding:2px 8px;font-size:10px}.stat-number{font-size:18px}}
