html,body{height:100%;margin:0;padding:0}#root{flex-direction:column;height:100%;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.gpx-importer{border:2px dashed var(--accent);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;padding:2rem 3rem;transition:background .2s}.gpx-importer:hover,.gpx-importer:focus{background:rgba(var(--accent-rgb), .08);outline:none}.gpx-icon{font-size:2.5rem}.gpx-label{color:var(--accent);margin:.5rem 0 .25rem;font-size:1.1rem;font-weight:600}.gpx-hint{color:var(--text-muted);margin:0;font-size:.85rem}.criteria-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem}.criteria-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.criteria-header h2{margin:0;font-size:1.1rem}.criteria-toggle{color:var(--text-muted);font-size:.9rem}.criteria-desc{color:var(--text-muted);margin:.5rem 0 1rem;font-size:.85rem}.criteria-grid{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.criterion-row{border-radius:8px;justify-content:space-between;align-items:center;gap:1rem;padding:.4rem .5rem;transition:background .15s;display:flex}.criterion-row:hover{background:#ffffff0a}.criterion-row.excluded{opacity:.45}.criterion-label{white-space:nowrap;text-overflow:ellipsis;cursor:default;flex:1;font-size:.9rem;position:relative;overflow:hidden}.criterion-hint{background:var(--border);cursor:help;vertical-align:middle;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;margin-left:.3rem;font-size:.7rem;display:inline-flex}.criterion-tooltip{border:1px solid var(--border);width:220px;color:var(--text-main);z-index:100;pointer-events:none;white-space:normal;background:#1e2a3a;border-radius:8px;padding:.5rem .75rem;font-size:.78rem;line-height:1.4;display:none;position:absolute;top:120%;left:0}.criterion-hint:hover+.criterion-tooltip,.criterion-label:focus-within .criterion-tooltip{display:block}.criterion-controls{flex-shrink:0;align-items:center;gap:.6rem;display:flex}.criterion-controls input[type=range]{width:100px;accent-color:var(--accent)}.criterion-value{text-align:center;width:1.5rem;color:var(--accent);font-size:.9rem;font-weight:600}.exclude-label{color:var(--text-muted);cursor:pointer;white-space:nowrap;align-items:center;gap:.3rem;font-size:.8rem;display:flex}.criteria-actions{flex-wrap:wrap;gap:.5rem;display:flex}.filter-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem}.filter-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;display:flex}.filter-header h2{margin:0;font-size:1.1rem}.filter-toggle{color:var(--text-muted);font-size:.9rem}.filter-desc{color:var(--text-muted);margin:.5rem 0 1rem;font-size:.85rem}.filter-show-hidden,.filter-state{margin-bottom:.85rem}.filter-state-label{color:var(--text-main);margin-bottom:.35rem;font-size:.88rem;font-weight:600;display:block}.filter-state-select{background:var(--bg);border:1px solid var(--border);width:100%;min-height:88px;color:var(--text-main);border-radius:6px;padding:.35rem .45rem;font-size:.9rem}.filter-state-hint{color:var(--text-muted);margin:.35rem 0 0;font-size:.78rem}.filter-ownership{margin-bottom:.85rem}.filter-ownership-label{color:var(--text-main);margin-bottom:.35rem;font-size:.88rem;font-weight:600;display:block}.filter-ownership-select{background:var(--bg);border:1px solid var(--border);width:100%;min-height:88px;color:var(--text-main);border-radius:6px;padding:.35rem .45rem;font-size:.9rem}.filter-length{margin-bottom:.85rem}.filter-length-label{color:var(--text-main);margin-bottom:.35rem;font-size:.88rem;font-weight:600;display:block}.filter-length-input{background:var(--bg);border:1px solid var(--border);color:var(--text-main);border-radius:6px;flex:1;min-width:0;padding:.35rem .45rem;font-size:.9rem}.filter-length-controls{align-items:center;gap:.4rem;display:flex}.filter-length-op{background:var(--bg);border:1px solid var(--border);color:var(--text-main);white-space:nowrap;border-radius:6px;flex-shrink:0;padding:.35rem .4rem;font-size:.85rem}.filter-deepest-pit{margin-bottom:.85rem}.filter-deepest-pit-label{color:var(--text-main);margin-bottom:.35rem;font-size:.88rem;font-weight:600;display:block}.filter-deepest-pit-input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-main);border-radius:6px;padding:.35rem .45rem;font-size:.9rem}.filter-rules{flex-direction:column;gap:.6rem;margin-bottom:.75rem;display:flex}.filter-rule{cursor:pointer;align-items:center;gap:.5rem;font-size:.9rem;display:flex;position:relative}.filter-rule-label{flex:1}.filter-rule-hint{background:var(--border);cursor:help;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;font-size:.7rem;display:inline-flex}.filter-rule-tooltip{border:1px solid var(--border);width:240px;color:var(--text-main);z-index:100;pointer-events:none;white-space:normal;background:#1e2a3a;border-radius:8px;padding:.5rem .75rem;font-size:.78rem;line-height:1.4;display:none;position:absolute;top:120%;left:0}.filter-rule-hint:hover~.filter-rule-tooltip{display:block}.filter-actions{flex-wrap:wrap;gap:.5rem;display:flex}.location-selector{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem 1.25rem}.location-selector h3{margin:0 0 .25rem;font-size:1rem}.loc-desc{color:var(--text-muted);margin:0 0 .75rem;font-size:.83rem}.loc-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.loc-row label{color:var(--text-muted);flex-direction:column;gap:.25rem;font-size:.83rem;display:flex}.loc-row input[type=number]{background:var(--bg);border:1px solid var(--border);width:130px;color:var(--text-main);border-radius:6px;padding:.4rem .6rem;font-size:.9rem}.loc-error{color:#f87171;margin:.4rem 0 0;font-size:.83rem}.loc-active{color:#4ade80;margin:.4rem 0 0;font-size:.83rem}.cave-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;align-items:stretch;gap:0;transition:box-shadow .15s;display:flex}.cave-card:hover{box-shadow:0 2px 12px #00000059}.cave-card.card-visited{border-color:#4ade8059}.cave-card.card-want{border-color:#facc1559}.cave-card.card-favorite{border-color:#f472b673}.cave-card.card-hidden{opacity:.75;border-style:dashed}.cave-select{border-right:1px solid var(--border);background:#ffffff04;flex-shrink:0;justify-content:center;align-items:center;width:2rem;display:flex}.cave-select input{width:.95rem;height:.95rem}.cave-rank{border-right:1px solid var(--border);background:#ffffff08;flex-shrink:0;justify-content:center;align-items:center;width:3rem;font-size:1.1rem;font-weight:700;display:flex}.cave-main{flex:1;min-width:0;padding:.75rem 1rem}.cave-name-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.4rem;display:flex}.cave-name{font-size:1rem;font-weight:600}.cave-pills{flex-wrap:wrap;gap:.3rem;display:flex}.pill{background:#ffffff14;border:1px solid #0000;border-radius:20px;padding:.1rem .5rem;font-size:.72rem;font-weight:500;display:inline-block}.pill-visited{color:#4ade80;background:#4ade8026;border-color:#4ade8066}.pill-want{color:#facc15;background:#facc1526;border-color:#facc1566}.pill-favorite{color:#f472b6;background:#f472b626;border-color:#f472b673}.pill-hidden{color:#cbd5e1;background:#94a3b833;border-color:#94a3b873}.pill-warn{color:#f87171;background:#f8717126;border-color:#f8717166}.cave-stats{flex-wrap:wrap;gap:.5rem 1rem;display:flex}.cave-stat{color:var(--text-muted);font-size:.8rem}.cave-notes{color:var(--text-muted);margin:.4rem 0 0;font-size:.82rem;font-style:italic}.cave-right{border-left:1px solid var(--border);background:#ffffff05;flex-direction:column;flex-shrink:0;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;display:flex}.cave-score{text-align:center;font-size:1.6rem;font-weight:700;line-height:1}.score-breakdown-popup{z-index:1000;background:var(--surface,#1e1e2e);border:1px solid var(--border,#333);min-width:260px;color:var(--text-main,#eee);white-space:nowrap;pointer-events:none;border-radius:10px;padding:.75rem 1rem;font-size:.82rem;font-weight:400;position:fixed;box-shadow:0 4px 24px #00000080}.score-breakdown-title{color:var(--text-main);margin-bottom:.5rem;font-size:.88rem;font-weight:700}.score-breakdown-divider{color:var(--text-muted,#888);text-transform:uppercase;letter-spacing:.05em;margin:.4rem 0 .25rem;font-size:.75rem}.score-breakdown-row{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.sbd-label{text-overflow:ellipsis;color:var(--text-main);flex:0 0 130px;overflow:hidden}.sbd-bar-wrap{background:#ffffff1a;border-radius:4px;flex:1;height:8px;overflow:hidden}.sbd-bar{background:#4ade80;border-radius:4px;height:100%;transition:width .2s;display:block}.sbd-contrib{text-align:right;color:var(--text-muted,#888);flex:0 0 28px;font-size:.78rem}.score-breakdown-skipped .sbd-label{color:var(--text-muted,#888)}.sbd-skip-reason{color:var(--text-muted,#888);flex:1;font-size:.75rem;font-style:italic}.score-label{color:var(--text-muted);margin-left:1px;font-size:.7rem;font-weight:400}.cave-actions{gap:.3rem;display:flex}.action-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.2rem;font-size:1.1rem;line-height:1;transition:background .15s}.action-btn:hover{background:var(--border)}.cave-list{flex-direction:column;gap:.5rem;display:flex}.cave-list-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:.95rem}.list-toolbar{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.list-select-all{color:var(--text-muted);align-items:center;gap:.35rem;font-size:.82rem;display:inline-flex}.list-bulk-btn{padding:.35rem .65rem;font-size:.82rem}.list-selected-count{color:var(--text-main);font-size:.82rem}.list-search{background:var(--surface);border:1px solid var(--border);color:var(--text-main);border-radius:8px;min-width:180px;padding:.4rem .7rem;font-size:.9rem}.list-search:focus{border-color:var(--accent);outline:none}.list-filters{flex-wrap:wrap;gap:.4rem;display:flex}.filter-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:.3rem .75rem;font-size:.82rem;transition:all .15s}.filter-btn:hover{background:var(--border);color:var(--text-main)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.list-count{color:var(--text-muted);margin-left:auto;font-size:.82rem}.list-cards{flex-direction:column;gap:.5rem;display:flex}.modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;width:100%;max-width:620px;max-height:90vh;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.modal-header h2{margin:0;font-size:1.15rem}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:1.1rem}.modal-close:hover{background:var(--border);color:var(--text-main)}.modal-body{flex:1;padding:1rem 1.25rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:.75rem;padding:.75rem 1.25rem;display:flex}.detail-section{margin-bottom:1.25rem}.detail-section h3{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);margin:0 0 .75rem;padding-bottom:.25rem;font-size:.85rem}.detail-field{align-items:flex-start;gap:.75rem;margin-bottom:.6rem;display:flex}.field-label{color:var(--text-muted);flex-shrink:0;min-width:170px;padding-top:.35rem;font-size:.85rem}.field-value{flex:1}.field-value input[type=text],.field-value input[type=number]{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-main);border-radius:6px;padding:.35rem .6rem;font-size:.9rem}.field-value input[type=range]{width:100%;accent-color:var(--accent)}.field-value textarea{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-main);resize:vertical;border-radius:6px;padding:.4rem .6rem;font-family:inherit;font-size:.9rem}.radio-group,.checkbox-group{flex-wrap:wrap;gap:1rem;display:flex}.button-row{flex-wrap:wrap;gap:.5rem;display:flex}.map-hint{color:var(--text-muted);margin:0;font-size:.85rem}.radio-group label,.checkbox-group label{cursor:pointer;align-items:center;gap:.3rem;font-size:.88rem;display:flex}.range-label{color:var(--text-muted);font-size:.78rem}.btn-small{margin-left:.5rem;padding:.2rem .5rem;font-size:.78rem}.survey-notes{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text-muted);white-space:pre-wrap;border-radius:6px;padding:.6rem .8rem;font-family:inherit;font-size:.85rem;line-height:1.5}.field-value select{background:var(--bg);border:1px solid var(--border);color:var(--text-main);border-radius:6px;min-width:150px;padding:.4rem .6rem;font-family:inherit;font-size:.9rem}.list-switcher{border-bottom:1px solid var(--border);background:var(--surface);padding:.5rem 1rem 0}.list-tabs{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.list-tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:8px 8px 0 0;align-items:center;gap:.35rem;padding:.45rem .85rem;font-size:.88rem;transition:background .15s,color .15s;display:inline-flex}.list-tab:hover{color:var(--text-main);background:#ffffff0f}.list-tab.active{background:var(--bg);border-color:var(--border);color:var(--text-main);font-weight:600}.list-tab-count{background:var(--border);text-align:center;min-width:1.2rem;color:var(--text-muted);border-radius:99px;padding:.05rem .35rem;font-size:.72rem}.list-tab.active .list-tab-count{background:var(--accent);color:#000}.list-tab-new{color:var(--accent);border-style:dashed;border-color:var(--border);border-bottom:none}.list-tab-new:hover{background:rgba(var(--accent-rgb,99,179,237), .08);color:var(--accent)}.list-tab-wrap{align-items:center;display:flex}.list-tab-delete{color:var(--text-muted);cursor:pointer;opacity:.6;background:0 0;border:none;padding:0 .3rem;font-size:.75rem;line-height:1}.list-tab-delete:hover{color:#f87171;opacity:1}.list-new-form,.list-rename-form{align-items:center;gap:.35rem;padding:.2rem .4rem;display:flex}.list-new-form input,.list-rename-form input{background:var(--bg);border:1px solid var(--accent);color:var(--text-main);border-radius:6px;width:130px;padding:.3rem .5rem;font-size:.88rem}.list-tools{gap:.4rem;padding:.35rem 0 .55rem;display:flex}.list-import-input{display:none}:root{--bg:#0f172a;--surface:#1e293b;--border:#334155;--accent:#3b82f6;--accent-rgb:59, 130, 246;--text-main:#e2e8f0;--text-muted:#94a3b8}*,:before,:after{box-sizing:border-box}body{background:var(--bg);color:var(--text-main);min-height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:.45rem 1rem;font-size:.9rem;font-weight:600;transition:filter .15s}.btn-primary:hover{filter:brightness(1.15)}.btn-secondary{color:var(--text-main);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:.45rem 1rem;font-size:.9rem;transition:background .15s}.btn-secondary:hover{background:var(--border)}.btn-ghost{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.4rem .8rem;font-size:.85rem;transition:background .15s,color .15s}.btn-ghost:hover{background:var(--border);color:var(--text-main)}.btn-danger{color:#f87171}.btn-danger:hover{background:#f8717126}.btn-large{padding:.75rem 2rem;font-size:1rem}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex}.header-left{align-items:center;gap:.75rem;display:flex}.app-logo{font-size:2rem;line-height:1}.app-title{letter-spacing:.02em;margin:0;font-size:1.4rem}.app-subtitle{color:var(--text-muted);margin:0;font-size:.78rem}.header-right{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.cave-count{color:var(--text-muted);background:var(--bg);border-radius:20px;padding:.25rem .6rem;font-size:.82rem}.app-body{flex:1;min-height:0;display:flex;overflow:hidden}.app-sidebar{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:360px;display:flex;overflow:hidden}.sidebar-tabs{border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.tab-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.6rem .5rem;font-size:.82rem;transition:all .15s}.tab-btn:hover{color:var(--text-main);background:#ffffff08}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:#3b82f60f}.sidebar-content{flex:1;padding:1rem;overflow-y:auto}.tab-pane{flex-direction:column;gap:1rem;display:flex}.import-note{color:var(--text-muted);margin:0;font-size:.78rem;line-height:1.5}.app-main{flex:1;padding:1.25rem;overflow-y:auto}.welcome{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100%;padding:3rem 1rem;display:flex}.welcome-icon{font-size:4rem}.welcome h2{margin:0;font-size:1.6rem}.welcome p{color:var(--text-muted);max-width:480px;margin:0;line-height:1.6}@media (width<=700px){.app-sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%}.app-body,.app-body.sidebar-open{flex-direction:column}}
