:root{--bg:#f4f2ee;--surface:#fff;--sidebar-bg:#1a2336;--accent-gold:#c5a059;--accent-navy:#1a237e;--text-primary:#263238;--text-secondary:#607d8b;--border:#dde1e7;--pass:#27ae60;--fail:#e74c3c;--announcement:#1565c0;--deadline:#e65100;--shadow-sm:0 1px 4px #00000012;--shadow-md:0 4px 16px #0000001a;--radius:10px;--sidebar-w:272px}body{background:var(--bg);color:var(--text-primary);height:100vh;font-family:Inter,Noto Sans JP,sans-serif;font-size:13px;overflow:hidden}#mobile-overlay{z-index:25;background:#00000073;display:none;position:fixed;inset:0}#mobile-overlay.visible{display:block}.app-container{height:100vh;display:flex;overflow:hidden}.side-panel{background:var(--sidebar-bg);color:#cfd8dc;border-radius:var(--radius);box-shadow:var(--shadow-md);flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.resize-handle{cursor:col-resize;touch-action:none;-webkit-user-select:none;user-select:none;background:#0000000a;border-radius:4px;flex:0 0 12px;justify-content:center;align-self:stretch;align-items:center;margin:0 -3px;transition:background .15s;display:flex}.resize-handle:after{content:"";background:#00000038;border-radius:2px;width:2px;height:32px}.resize-handle:hover{background:#00000014}.resize-handle:hover:after{background:var(--accent-navy)}.sidebar-section-label{letter-spacing:1.1px;text-transform:uppercase;color:var(--accent-gold);flex-shrink:0;padding:10px 14px 2px;font-size:9px;font-weight:700}.sidebar-hint{color:#ffffff40;flex-shrink:0;padding:0 14px 8px;font-size:10px;line-height:1.4}.exam-year-radio{flex-shrink:0;gap:8px;padding:12px 14px 8px;display:flex}.exam-year-opt{cursor:pointer;-webkit-user-select:none;user-select:none;background:#ffffff08;border:1px solid #ffffff1f;border-radius:9px;flex:1;align-items:center;gap:7px;padding:7px 10px;transition:background .15s,border-color .15s;display:flex}.exam-year-opt:hover{background:#ffffff12}.exam-year-opt.active{border-color:var(--accent-gold);background:#c5a0591f}.exam-year-opt input{opacity:0;width:0;height:0;position:absolute}.exam-year-mark{border:2px solid #ffffff59;border-radius:50%;flex-shrink:0;width:14px;height:14px;transition:border-color .15s,box-shadow .15s;position:relative}.exam-year-opt.active .exam-year-mark{border-color:var(--accent-gold)}.exam-year-opt.active .exam-year-mark:after{content:"";background:var(--accent-gold);border-radius:50%;position:absolute;inset:2px}.exam-year-text{color:#ffffff8c;font-size:12px;font-weight:700}.exam-year-opt.active .exam-year-text{color:#fff}.exam-year-note{color:#fff6;border:1px solid #fff3;border-radius:4px;margin-left:auto;padding:0 4px;font-size:9px}.school-list-scroll{scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;flex:1;padding:0 6px 12px;overflow-y:auto}.school-list-scroll::-webkit-scrollbar{width:4px}.school-list-scroll::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.pref-section{margin-bottom:1px}.pref-hdr{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;transition:background .15s;display:flex}.pref-hdr:hover{background:#ffffff0d}.pref-hdr.open{background:#ffffff08}.pref-arrow{color:var(--accent-gold);flex-shrink:0;width:10px;font-size:10px}.pref-name{color:#ffffffe0;flex:1;font-size:12px;font-weight:700}.pref-count{color:#ffffff47;font-size:10px}.pref-count b{color:var(--accent-gold)}.pref-body{padding-left:6px}.gender-group{margin-bottom:1px}.gender-hdr{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:5px;align-items:center;gap:5px;padding:4px 8px;transition:background .15s;display:flex}.gender-hdr:hover{background:#ffffff0a}.gender-arrow{color:#ffffff4d;flex-shrink:0;width:8px;font-size:9px}.gender-name{color:#ffffff8c;flex:1;font-size:11px}.gender-count{color:#ffffff40;font-size:10px}.gender-count b{color:var(--accent-gold)}.gender-badge{color:#fff;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:14px;font-size:9px;font-weight:800;display:inline-flex}.badge-boy{background:#1565c0}.badge-girl{background:#c2185b}.badge-co{background:#2e7d32}.school-item{cursor:pointer;border:1px solid #0000;border-radius:6px;margin:1px 0 1px 4px;transition:border-color .2s,background .2s}.school-item.selected{background:#c5a0590f;border-color:#c5a05947}.school-item.commute-highlighted{background:#c5a0591f;border-color:#c5a0598c}.school-item:focus-visible{border-color:#c5a0598c;outline:none}.school-hdr{align-items:center;gap:7px;padding:5px 8px;display:flex}.school-hdr.clickable{cursor:pointer;border-radius:5px;transition:background .12s}.school-hdr.clickable:hover{background:#ffffff0d}.school-arrow{color:#ffffff4d;flex-shrink:0;width:8px;font-size:8px}.school-exam-count{color:#ffffff80;background:#ffffff1a;border-radius:4px;flex-shrink:0;padding:0 5px;font-size:9px}.school-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.school-lbl{color:#ffffffd1;flex:1;font-size:11px;font-weight:600}.priority-pill{color:#fff;opacity:.9;border-radius:8px;flex-shrink:0;padding:1px 6px;font-size:9px;font-weight:700}.exam-row{cursor:pointer;border-radius:4px;align-items:center;gap:5px;margin:1px 2px;padding:3px 8px 3px 22px;transition:background .12s;display:flex}.exam-row:hover{background:#ffffff0a}.exam-row.checked{background:#27ae601a}.exam-row input[type=checkbox]{accent-color:var(--accent-gold);cursor:pointer;flex-shrink:0;width:11px;height:11px}.round-lbl{color:#fff9;flex:1;font-size:10px}.date-lbl{color:#ffffff59;font-variant-numeric:tabular-nums;font-size:9px}.time-lbl{color:#ffffff40;font-size:9px}.station-select-box{border-bottom:1px solid #ffffff12;margin-bottom:8px;padding:0 8px 12px}.station-search-container{padding:0 6px;position:relative}.station-input{color:#fff;box-sizing:border-box;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;outline:none;width:100%;padding:7px 10px;font-size:12px}.station-input:focus{border-color:var(--accent-gold);background:#ffffff14}.station-results{z-index:100;border:1px solid var(--accent-gold);background:#2c364a;border-radius:0 0 6px 6px;max-height:200px;position:absolute;top:100%;left:6px;right:6px;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.station-res-item{cursor:pointer;border-bottom:1px solid #ffffff0d;padding:8px 12px}.station-res-item:hover{background:#ffffff0d}.res-name{color:#fff;font-size:12px;font-weight:700;display:block}.res-line{color:#fff6;font-size:10px}.selected-station-pill{color:var(--accent-gold);background:#c5a05926;border-radius:6px;justify-content:space-between;align-items:center;margin:8px 6px 0;padding:6px 10px;font-size:11px;display:flex}.clear-station{color:var(--accent-gold);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px}.gender-filter-row{flex-wrap:wrap;gap:8px;padding:8px 6px 0;display:flex}.gender-filter-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:4px;display:flex}.gender-filter-label input[type=checkbox]{display:none}.gender-filter-badge{color:#fff;opacity:.4;border-radius:12px;padding:2px 10px;font-size:11px;font-weight:700;transition:opacity .15s}.gender-filter-label input[type=checkbox]:checked+.gender-filter-badge{opacity:1}.main-content{flex-direction:column;flex:1;gap:10px;min-width:0;padding:12px;display:flex;overflow:hidden}.panel-toggle-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);background:0 0;border-radius:6px;flex-shrink:0;padding:4px 10px;font-size:12px;transition:background .15s,color .15s}.panel-toggle-btn:hover{color:var(--accent-navy);background:#0000000f}.top-bar{flex-shrink:0;align-items:center;gap:10px;display:flex}.top-bar-text{flex-wrap:wrap;flex:1;align-items:center;gap:6px 20px;min-width:0;display:flex}.main-title{color:var(--accent-navy);white-space:nowrap;text-overflow:ellipsis;font-family:Outfit,sans-serif;font-size:18px;font-weight:700;overflow:hidden}.main-heading{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.main-desc{color:var(--text-secondary);margin:0;font-size:12px;line-height:1.4}.content-row{flex-direction:row;flex:1;gap:10px;min-height:0;display:flex;overflow:hidden}.main-area{flex-direction:column;flex:1;gap:10px;min-width:0;display:flex;overflow:hidden}.tab-nav{background:#0000000d;border-radius:8px;gap:4px;padding:3px;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:5px 12px;font-size:11px;font-weight:600;transition:all .2s}.tab-btn:hover{background:#ffffff80}.tab-btn.active{color:var(--accent-navy);shadow:var(--shadow-sm);background:#fff}.legend{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.legend-item{color:var(--text-secondary);align-items:center;gap:5px;font-size:11px;display:flex}.legend-item:before{content:"";border-radius:2px;width:20px;height:3px;display:inline-block}.legend-item.pass:before{background:var(--pass)}.legend-item.fail:before{background:var(--fail)}.legend-chip{border-radius:10px;padding:2px 7px;font-size:10px;font-weight:600}.legend-chip.announcement{color:var(--announcement);background:#e3f2fd}.legend-chip.deadline{color:var(--deadline);background:#fff3e0}.calendar-area{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);min-height:0;box-shadow:var(--shadow-sm);flex:1;display:flex;overflow:hidden}.left-axis-col{border-right:1px solid var(--border);z-index:10;background:#f8f9fa;flex-direction:column;flex-shrink:0;width:50px;display:flex}.time-axis{flex:1;min-height:0;overflow:hidden}.time-axis-corner{border-bottom:1px solid var(--border);background:#f0f2f5;width:100%}.time-tick{width:100%;color:var(--text-secondary);font-variant-numeric:tabular-nums;border-bottom:1px solid #eee;justify-content:center;align-items:flex-start;padding-top:3px;font-size:9px;display:flex}.after-label{color:#999;white-space:pre-line;background:#f2f2f2;border-top:1px dashed #ccc;justify-content:center;padding-top:8px;font-size:9px}.calendar-scroll{scrollbar-width:thin;scrollbar-color:#ccc transparent;flex:1;position:relative;overflow:auto}.calendar-scroll::-webkit-scrollbar{width:8px;height:8px}.calendar-scroll::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}#grid-canvas{z-index:1;display:block;position:absolute;top:0;left:0}.events-layer{z-index:5;position:absolute;top:0;left:0}.connection-canvas{z-index:8;pointer-events:none;position:absolute;top:0;left:0}.exam-block{cursor:pointer;-webkit-user-select:none;user-select:none;background:#fdfdfd;border:1.5px solid #0000;border-left-width:4px;border-radius:6px;align-items:flex-start;gap:4px;padding:4px 5px;transition:box-shadow .15s,transform .15s;display:flex;position:absolute;overflow:hidden;box-shadow:0 1px 5px #00000014}.exam-block:hover{box-shadow:var(--shadow-md);z-index:20;transform:scale(1.02)}.exam-block.pass{border-color:var(--pass);background:#f0faf4}.exam-block.fail{border-color:var(--fail);opacity:.75;background:#fff4f4}.school-symbol{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:9px;font-weight:800;display:flex}.exam-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.school-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:10px;font-weight:700;overflow:hidden}.exam-time{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:8px}.exam-round-name{color:#bbb;font-size:8px}.result-badge{color:#fff;border-radius:8px;padding:1px 5px;font-size:9px;font-weight:700;position:absolute;bottom:3px;right:4px}.result-badge.pass{background:var(--pass)}.result-badge.fail{background:var(--fail)}.event-chip{white-space:nowrap;z-index:4;border:1px solid #0000;border-radius:8px;align-items:center;gap:4px;padding:2px 7px;font-size:9px;font-weight:600;display:flex;position:absolute}.chip-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.chip-announcement{color:var(--announcement);background:#e3f2fd;border-color:#bbdefb}.chip-deadline{color:var(--deadline);background:#fff3e0;border-color:#ffe0b2}.end-node{background:var(--accent-navy);color:#fff;white-space:nowrap;z-index:6;border-radius:20px;padding:6px 14px;font-size:11px;font-weight:700;position:absolute;box-shadow:0 2px 10px #1a237e4d}.deviation-pane{z-index:35;background:var(--surface);flex-shrink:0;position:sticky;bottom:0}.resize-handle-h{cursor:row-resize;border-top:1px solid var(--border);border-bottom:1px solid var(--border);touch-action:none;-webkit-user-select:none;user-select:none;background:#f0f2f5;height:8px;transition:background .15s}.resize-handle-h:hover{background:#0000001a}.deviation-body{align-items:stretch;display:flex;position:relative}.deviation-y-axis{background:#f8f9fa;flex-shrink:0;position:relative;overflow:hidden}.deviation-axis-title{text-align:center;color:var(--text-secondary);padding-top:4px;font-size:9px;font-weight:700}.deviation-tick{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:9px;position:absolute;right:6px;transform:translateY(-50%)}.deviation-empty-msg{z-index:2;color:var(--text-secondary);white-space:nowrap;align-self:center;margin-left:12px;font-size:12px;font-style:italic;position:sticky;left:12px}@media (max-width:768px){body{overflow:hidden}.main-content{gap:8px;padding:8px}.top-bar{flex-wrap:wrap;gap:6px}.top-bar-text{flex-direction:column;align-items:stretch;gap:8px}.main-title{font-size:15px}.main-sub,.main-desc{display:none}.tab-nav{width:100%;overflow-x:auto}.legend{gap:6px}.legend-chip{display:none}.calendar-area{border-radius:6px}}@media (max-width:480px){.legend{display:none}.main-title{font-size:14px}}.updates-container{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);scrollbar-width:thin;flex-direction:column;flex:1;gap:20px;padding:24px;display:flex;overflow-y:auto}.updates-title{color:var(--accent-navy);margin:0;font-family:Outfit,sans-serif;font-size:20px;font-weight:700}.updates-subtitle{color:var(--text-secondary);margin:-10px 0 10px;font-size:12px}.region-section{border:1px solid var(--border);background:#fdfdfd;border-radius:8px;padding:16px;box-shadow:0 1px 3px #00000008}.region-title{color:var(--accent-navy);border-bottom:1.5px solid #eaeaea;align-items:center;gap:8px;margin:0 0 12px;padding-bottom:6px;font-size:14px;font-weight:700;display:flex}.title-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.title-dot.kanto{background:#1565c0}.title-dot.kansai{background:#2e7d32}.title-dot.other{background:#757575}.updates-table-wrapper{width:100%;overflow-x:auto}.updates-table{border-collapse:collapse;text-align:left;width:100%;font-size:12px}.updates-table th{color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap;background:#f8f9fa;padding:10px 12px;font-size:11px;font-weight:700}.updates-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s,color .2s}.updates-table th.sortable:hover{color:var(--accent-navy);background:#eef1f6}.updates-table td{vertical-align:middle;border-bottom:1px solid #f1f3f5;padding:12px}.update-row{transition:background .15s}.update-row:hover{background:#fafbfc}.td-date{color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap;width:130px}.td-pref{color:var(--text-primary);white-space:nowrap;width:80px;font-weight:600}.td-school{color:var(--accent-navy);white-space:nowrap;width:160px;font-weight:700}.school-link{color:var(--accent-navy);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .15s}.school-link:hover{border-bottom-color:var(--accent-navy)}.td-category{width:80px}.cat-badge{color:#fff;white-space:nowrap;border-radius:4px;justify-content:center;align-items:center;padding:3px 8px;font-size:10px;font-weight:700;display:inline-flex}.cat-badge.badge-orange{background:var(--deadline)}.cat-badge.badge-blue{background:var(--announcement)}.cat-badge.badge-green{background:var(--pass)}.cat-badge.badge-gray{background:#78909c}.td-desc{color:var(--text-primary);word-break:break-all;line-height:1.4}.no-updates-msg{text-align:center;color:#b0bec5;background:#fafafa;border:1px dashed #e0e0e0;border-radius:6px;padding:20px;font-style:italic}.updates-loading,.updates-error{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);flex:1;justify-content:center;align-items:center;padding:40px;font-size:14px;font-weight:600;display:flex}.updates-error{color:var(--fail)}@media (max-width:768px){.updates-container{gap:16px;padding:16px}.region-section{padding:12px}.updates-table td{padding:8px}}.welcome-card{color:#fff;box-shadow:var(--shadow-md);background:linear-gradient(135deg,#1a2336 0%,#101726 100%);border:1px solid #ffffff0d;border-radius:8px;flex-shrink:0;padding:20px 24px}.welcome-hdr{align-items:center;gap:16px;margin-bottom:18px;display:flex}.welcome-logo{background:linear-gradient(135deg, var(--accent-gold), #7a5820);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-family:Outfit,sans-serif;font-size:20px;font-weight:700;display:flex;box-shadow:0 4px 10px #c5a0594d}.welcome-title{color:#fff;letter-spacing:.5px;margin:0;font-family:Outfit,sans-serif;font-size:18px;font-weight:700}.welcome-tagline{color:#fff9;margin:3px 0 0;font-size:11px}.welcome-grid{border-top:1px solid #ffffff1a;grid-template-columns:repeat(3,1fr);gap:20px;padding-top:16px;display:grid}.intro-item{gap:12px;display:flex}.intro-icon{flex-shrink:0;margin-top:2px;font-size:20px}.intro-content{flex-direction:column;gap:4px;display:flex}.intro-label{color:var(--accent-gold);font-size:11px;font-weight:700}.intro-desc{color:#ffffffb3;font-size:10px;line-height:1.45}@media (max-width:900px){.welcome-grid{grid-template-columns:1fr;gap:14px}}.cal-tab-layout{border-radius:var(--radius);border:1px solid var(--border);min-height:0;box-shadow:var(--shadow-sm);flex-direction:row;flex:1;display:flex;overflow:hidden}.cal-selector-panel{background:var(--sidebar-bg);color:#cfd8dc;flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.cal-selector-header{border-bottom:1px solid #ffffff12;flex-shrink:0;padding:13px 14px 10px}.cal-selector-title{color:#ffffff80;letter-spacing:.06em;text-transform:uppercase;font-size:11px;font-weight:700}.cal-selector-search{border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:8px 10px}.cal-search-input{color:#cfd8dc;box-sizing:border-box;background:#ffffff12;border:1px solid #ffffff24;border-radius:6px;outline:none;width:100%;padding:6px 10px;font-family:inherit;font-size:12px}.cal-search-input::placeholder{color:#ffffff4d}.cal-search-input:focus{background:#ffffff1c;border-color:#ffffff47}.cal-selector-list{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;flex-direction:column;flex:1;min-height:0;padding:4px 0;display:flex;overflow-y:auto}.cal-region-group{flex-direction:column;margin-bottom:4px;display:flex}.cal-region-header{color:#ffffff4d;letter-spacing:.07em;text-transform:uppercase;padding:8px 12px 3px;font-size:10px;font-weight:700}.cal-school-item{color:#cfd8dc;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:5px 12px;font-family:inherit;font-size:12px;transition:background .12s;display:flex}.cal-school-item:hover{background:#ffffff0f}.cal-school-item.selected{color:#fff;background:#ffffff1f}.cal-school-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.cal-school-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.cal-empty-msg{color:#ffffff40;text-align:center;padding:16px 12px;font-size:11px}.cal-main-area{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);min-height:0;box-shadow:var(--shadow-sm);scrollbar-width:thin;flex:1;padding:20px 24px;overflow-y:auto}.cal-school-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.cal-school-color-bar{border-radius:2px;flex-shrink:0;width:4px;height:22px}.cal-school-title{color:var(--text-primary);margin:0;font-size:17px;font-weight:700}.cal-school-link{color:var(--accent-navy);border:1px solid var(--accent-navy);opacity:.7;border-radius:10px;padding:2px 8px;font-size:11px;text-decoration:none;transition:opacity .15s}.cal-school-link:hover{opacity:1}.cal-placeholder{color:var(--text-secondary);background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.cal-placeholder-icon{opacity:.25;font-size:44px}.cal-placeholder-text{color:var(--text-secondary);font-size:14px;font-weight:600}.cal-placeholder-sub{color:var(--text-secondary);opacity:.7;font-size:11px}.cal-loading{height:160px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:13px;display:flex}.cal-no-events{color:var(--text-secondary);padding:8px 0;font-size:12px;font-style:italic}.contribution-calendar-wrapper{flex-direction:column;gap:20px;display:flex}.contribution-graph{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:16px 20px 14px}.contribution-graph.graph-sub{opacity:.65}.graph-year-label{color:var(--text-primary);margin-bottom:10px;font-size:13px;font-weight:700}.graph-tooltip{color:#fff;background:#263238;border-radius:6px;min-width:120px;max-width:260px;padding:8px 11px;font-size:11px;box-shadow:0 4px 14px #0000004d}.tooltip-date{color:#ffffff8c;margin-bottom:5px;font-size:10px;font-weight:700}.tooltip-event{align-items:center;gap:6px;padding:2px 0;font-size:11px;display:flex}.tooltip-link{color:#90caf9;text-decoration:none}.graph-legend{color:var(--text-secondary);flex-wrap:wrap;gap:14px;padding:0 2px;font-size:11px;display:flex}.legend-chip-item{align-items:center;gap:5px;display:flex}.custom-school-marker{background:0 0;border:none}.school-marker-wrap{width:100%;height:100%;position:relative}.school-marker-dot{opacity:.5;box-sizing:border-box;border:.25px solid;border-radius:50%;width:100%;height:100%;transition:opacity .15s;box-shadow:0 1px 3px #0000004d}.school-marker-dot.highlighted{opacity:1;border:2px solid #fff;box-shadow:0 0 0 2px #c5a059e6,0 2px 6px #00000073}.school-marker-label{white-space:nowrap;color:#333;text-shadow:0 0 2px #fff,0 0 2px #fff,0 0 3px #fff;pointer-events:none;background:0 0;padding:1px 4px;font-size:10px;font-weight:600;line-height:1.2;position:absolute;top:50%;left:130%;transform:translateY(-50%)}.school-marker-label.highlighted{color:#1a1a1a;z-index:1;font-weight:700}
