/* ===== RESET & VARIABLES ===== */
*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0f1420;--panel:#151c2e;--accent:#e8a838;--text:#d8d8e0;--dim:#778;--card:#1a2235;--green:#4caf50;--orange:#ff9800;--red:#e05050}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);overflow:hidden;height:100dvh;display:flex;flex-direction:column;padding-bottom:56px}
button{font-family:inherit}

/* ===== TOPBAR 44px ===== */
.topbar{background:var(--panel);padding:0 8px;display:flex;align-items:center;gap:6px;height:44px;flex-shrink:0;border-bottom:1px solid #252a40}
.logo{font-size:1em;color:var(--accent);white-space:nowrap;font-weight:700}
.logo small{font-size:.55em;color:var(--dim);font-weight:400;vertical-align:middle}
.month-ctrl{display:flex;align-items:center;gap:4px;flex:1;min-width:0}
.month-ctrl input[type=range]{flex:1;accent-color:var(--accent);min-width:50px;height:22px}
.month-name{font-weight:700;color:var(--accent);font-size:.95em;min-width:32px}
.alt-badge{font-size:.75em;color:var(--dim);background:#1a2030;padding:2px 6px;border-radius:8px;white-space:nowrap}
.alt-badge b{color:var(--accent)}
.scan-badge{font-size:.65em;padding:2px 5px;border-radius:8px;white-space:nowrap;display:none;max-width:140px;overflow:hidden;text-overflow:ellipsis}
.scan-badge.scanning{display:inline;background:#2a2a10;color:var(--orange);animation:pulse 1s infinite}
.scan-badge.done{display:inline;background:#1a2a1a;color:var(--green)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ===== SEARCH BAR 44px ===== */
.search-bar{background:#0a0e18;padding:0 8px;display:flex;gap:5px;align-items:center;height:44px;flex-shrink:0;border-bottom:1px solid #252a40}
.search-wrap{position:relative;flex:1;display:flex;min-width:0}
.search-bar input{flex:1;background:var(--card);border:1px solid #333;color:var(--text);border-radius:10px;padding:6px 12px;font-size:.9em;outline:none;min-width:0;height:34px}
.search-bar input:focus{border-color:var(--accent)}
.search-bar input::placeholder{color:#555}
.search-btn{background:var(--accent);color:var(--bg);border:none;border-radius:10px;padding:0 12px;font-size:.9em;font-weight:700;cursor:pointer;height:34px;flex-shrink:0}
.btn-icon{background:var(--accent);color:var(--bg);border:none;border-radius:50%;width:34px;height:34px;font-size:1em;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.btn-icon:active{opacity:.7}
.search-results{position:absolute;top:100%;left:0;right:0;background:var(--panel);border:1px solid #333;border-radius:0 0 8px 8px;max-height:250px;overflow-y:auto;z-index:1000;display:none;font-size:.9em}
.search-results.open{display:block}
.sr-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid #1a1a2a;min-height:44px;display:flex;align-items:center}
.sr-item:hover{background:var(--card)}
.sr-item b{color:var(--accent)}
.sr-item span{color:var(--dim);font-size:.85em}
.loc-name{font-size:.7em;color:var(--green);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}

/* ===== SCORE BAR 40px ===== */
.score-bar{background:#0a0e18;padding:0 8px;display:flex;align-items:center;gap:8px;height:40px;flex-shrink:0;border-bottom:1px solid #252a40;cursor:pointer;overflow:hidden}
.score-go-badge{padding:5px 12px;border-radius:12px;font-weight:800;font-size:.9em;white-space:nowrap;flex-shrink:0;color:var(--dim)}
.score-go-badge.go{background:#1a3a1a;color:var(--green);border:1px solid var(--green)}
.score-go-badge.wait{background:#3a3010;color:var(--orange);border:1px solid var(--orange)}
.score-go-badge.no{background:#3a1a1a;color:var(--red);border:1px solid var(--red)}
.best-chip{display:flex;align-items:center;gap:6px;margin-left:auto;font-size:.85em;white-space:nowrap;overflow:hidden}
.best-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.best-name{font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis}
.best-score{font-weight:800;color:var(--accent);flex-shrink:0}

/* ===== MAP CONTAINER ===== */
.map-container{flex:1;min-height:0;position:relative}
#map{width:100%;height:100%}

/* ===== FLOAT SCORE (on map) ===== */
.float-score{position:absolute;top:10px;right:10px;z-index:800;padding:8px 14px;border-radius:14px;font-weight:900;font-size:1.1em;pointer-events:none;display:none;box-shadow:0 3px 16px rgba(0,0,0,.7);letter-spacing:.5px}
.float-score.go{display:block;background:rgba(26,58,26,.92);color:var(--green);border:2px solid var(--green)}
.float-score.wait{display:block;background:rgba(58,48,16,.92);color:var(--orange);border:2px solid var(--orange)}
.float-score.no{display:block;background:rgba(58,26,26,.92);color:var(--red);border:2px solid var(--red)}

/* ===== FAB TROUVAILLE ===== */
.fab-find{position:fixed;bottom:70px;right:16px;z-index:860;background:var(--accent);color:var(--bg);border:none;border-radius:50%;width:56px;height:56px;font-size:1.4em;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.6);font-family:inherit}
.fab-find:active{transform:scale(.92);opacity:.85}

/* ===== BOTTOM PANEL (slide-up) ===== */
.bottom-panel{position:fixed;bottom:56px;left:0;right:0;background:var(--panel);border-radius:12px 12px 0 0;border-top:2px solid var(--accent);z-index:850;height:0;overflow:hidden;transition:height .3s ease}
.bottom-panel.open{overflow:hidden}
.bottom-panel.dragging{transition:none}
.panel-handle{display:flex;justify-content:center;padding:10px 0 4px;cursor:grab;touch-action:none}
.handle-bar{width:36px;height:4px;background:#555;border-radius:2px}
.panel-scroll{height:calc(100% - 26px);overflow-y:auto;padding:0 10px 16px;-webkit-overflow-scrolling:touch}
.panel-title{color:var(--accent);font-size:.95em;margin-bottom:6px}
.tab-content{display:none}
.tab-content.active{display:block}

/* ===== PANEL SECTIONS ===== */
.panel-section{margin-top:12px;padding-top:8px;border-top:1px solid #252a40}
.section-title{color:var(--accent);font-size:.85em;margin-bottom:6px;font-weight:600}
.layer-controls{display:flex;flex-wrap:wrap;gap:8px 12px}
.layer-controls label{display:flex;align-items:center;gap:4px;cursor:pointer;color:var(--dim);font-size:.85em;min-height:32px}
.layer-controls input{accent-color:var(--accent);width:18px;height:18px}
.radius-ctrl{display:flex;align-items:center;gap:8px}
.radius-ctrl input[type=range]{flex:1;accent-color:var(--accent);height:22px}
#radiusLabel{font-size:.9em;color:var(--accent);font-weight:700;min-width:40px}
/* ===== GPS ACCURACY BADGE ===== */
.gps-accuracy-badge{position:fixed;bottom:126px;left:12px;z-index:860;background:rgba(21,28,46,.92);border:1px solid #4488ff;color:#88bbff;padding:4px 10px;border-radius:8px;font-size:.75em;font-weight:600;pointer-events:none}
.gps-accuracy-badge.warn{border-color:var(--orange);color:var(--orange)}

/* ===== FIND BANNER ===== */
.find-banner{position:fixed;top:88px;left:8px;right:8px;z-index:870;background:rgba(21,28,46,.95);border:2px solid var(--accent);border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(0,0,0,.6)}
.find-banner-text{flex:1;color:var(--text);font-size:.85em;font-weight:600}
.find-banner-btn{background:var(--green);color:#000;border:none;padding:8px 14px;border-radius:8px;font-weight:700;font-size:.85em;cursor:pointer;min-height:40px;white-space:nowrap}
.find-banner-cancel{background:transparent;border:1px solid var(--red);color:var(--red);padding:8px 10px;border-radius:8px;font-size:.8em;cursor:pointer;min-height:40px;white-space:nowrap}

/* ===== TREE PHOTO GRID ===== */
.tree-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;margin:6px 0}
.tree-card{background:#111825;border-radius:6px;padding:4px;text-align:center;cursor:pointer}
.tree-card img{width:100%;height:60px;object-fit:cover;border-radius:4px;background:#222}
.tree-card .tree-name{font-size:.7em;color:var(--text);font-weight:600;margin-top:2px;line-height:1.2}
.tree-card .tree-indic{font-size:.6em;color:var(--dim);line-height:1.1}

/* ===== BOTTOM NAV 56px ===== */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:900;background:var(--panel);border-top:2px solid var(--accent);display:flex}
.bottom-nav .tab-btn{flex:1;padding:6px 4px;background:var(--panel);border:none;color:var(--dim);font-size:.82em;cursor:pointer;border-top:2px solid transparent;min-height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.bottom-nav .tab-btn.active{color:var(--accent);border-top-color:var(--accent);background:#1a2540}
.bottom-nav .tab-btn .tab-icon{font-size:1.3em}
.bottom-nav .tab-btn .tab-label{font-size:.65em}

/* ===== WX BAR (inside panel) ===== */
.wx-bar{padding:6px 0;display:flex;gap:5px;overflow-x:auto;align-items:center;min-height:34px;font-size:.82em;-webkit-overflow-scrolling:touch}
.wx-bar::-webkit-scrollbar{height:2px}
.wx-bar::-webkit-scrollbar-thumb{background:#333}
.wx-day{display:flex;flex-direction:column;align-items:center;min-width:42px;flex-shrink:0;padding:2px 3px;border-radius:4px}
.wx-day.today{background:rgba(232,168,56,.15);border:1px solid var(--accent)}
.wx-day .wx-icon{font-size:1.1em}
.wx-day .wx-rain{color:#5599dd;font-size:.7em}
.wx-day .wx-temp{font-size:.7em;color:var(--dim)}
.wx-score{padding:5px 10px;border-radius:12px;font-weight:800;font-size:.9em;white-space:nowrap;flex-shrink:0}
.wx-score.go{background:#1a3a1a;color:var(--green);border:1px solid var(--green)}
.wx-score.wait{background:#3a3010;color:var(--orange);border:1px solid var(--orange)}
.wx-score.no{background:#3a1a1a;color:var(--red);border:1px solid var(--red)}

/* ===== SPECIES SUMMARY (inside tab) ===== */
.sp-summary{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:.85em}
#spCount{color:var(--accent);font-weight:700;white-space:nowrap}
.sp-active-chips{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;flex:1}
.sp-active-chips::-webkit-scrollbar{height:2px}
.sp-active-chips .ac{padding:4px 9px;border-radius:10px;font-size:.75em;font-weight:700;white-space:nowrap;flex-shrink:0;cursor:pointer;border:2px solid;opacity:.9}

/* ===== SPECIES GRID ===== */
.sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:5px;padding:8px 0}
.sg{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:8px;border:2px solid #333;cursor:pointer;transition:all .12s;min-height:44px}
.sg:hover{border-color:#555;background:rgba(255,255,255,.03)}
.sg.on{border-color:var(--accent);background:rgba(255,172,64,.08)}
.sg .dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.sg .nm{font-size:.8em;font-weight:600;color:var(--text);flex:1;line-height:1.2}
.sg .sc{font-size:.72em;font-weight:800;padding:2px 5px;border-radius:5px}
.sc.h{background:rgba(76,175,80,.3);color:#6ddf6d}
.sc.m{background:rgba(255,152,0,.3);color:#ffb040}
.sc.l{background:rgba(224,80,80,.3);color:#ff7070}

/* ===== SPECIES CARDS ===== */
.sp-card{margin:4px 0;padding:6px;background:var(--card);border-radius:6px;border-left:4px solid}
.sp-card-header{display:flex;gap:6px;align-items:flex-start}
.sp-photo{width:65px;height:52px;border-radius:5px;object-fit:cover;background:#222;flex-shrink:0;cursor:pointer}
.sp-photo.loading{background:repeating-linear-gradient(90deg,#222,#2a2a3a 50%,#222 100%);background-size:200% 100%;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sp-card b{font-size:.95em}.sp-card i{color:#888;font-size:.75em}
.peak-badge{color:#fff;background:var(--accent);padding:1px 5px;border-radius:4px;font-size:.7em;font-weight:700;vertical-align:middle}
.fb{padding:2px 6px;border-radius:4px;font-size:.72em;font-weight:700;vertical-align:middle}
.fb-h{background:#1a3a1a;color:var(--green)}.fb-m{background:#3a3010;color:var(--orange)}.fb-l{background:#3a1a1a;color:var(--red)}
.tag{display:inline-block;padding:2px 5px;border-radius:4px;font-size:.75em;margin:1px}
.tag-sol{background:#3a2a10;color:#e8c87a}.tag-arbre{background:#1a3a1a;color:#80c080}.tag-alt{background:#1a2a3a;color:#80b0d0}
.sp-field{margin:2px 0;color:#aaa;font-size:.88em}.sp-field em{color:#7ab8e0}
.sp-tip{color:#7ab8e0;font-style:italic;margin-top:2px;font-size:.88em}
.sp-warn{color:var(--red);font-weight:600;margin-top:2px;font-size:.88em}
.sp-desc{color:#999;margin-top:2px;font-size:.86em}

/* ===== WEATHER DETAIL ===== */
.wx-detail{background:var(--card);border-radius:6px;padding:6px;margin:4px 0}
.wx-detail h4{color:var(--accent);font-size:.9em;margin-bottom:3px}
.wx-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:3px}
.wx-cell{background:#111825;padding:4px;border-radius:4px;text-align:center;font-size:.82em}
.wx-cell .val{font-size:1.05em;font-weight:700}.wx-cell .lbl{color:var(--dim);font-size:.82em}
.rain-history{display:flex;align-items:flex-end;gap:2px;height:40px;margin:3px 0}
.rain-bar{flex:1;background:#3366aa;border-radius:2px 2px 0 0;min-height:1px;position:relative}
.rain-bar .rv{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:.6em;color:#5599dd;white-space:nowrap}

/* ===== ALTITUDE GAUGE ===== */
.alt-band{background:var(--card);border-radius:4px;padding:4px;margin:3px 0;display:flex;align-items:center;gap:5px}
.alt-gauge{flex:1;height:7px;background:#111;border-radius:3px;position:relative;overflow:hidden}
.alt-fill{height:100%;border-radius:3px;position:absolute}
.alt-fill.zone{background:rgba(232,168,56,.25);border:1px solid var(--accent)}
.alt-fill.pos{background:var(--accent);width:4px}
.alt-lbl{font-size:.75em;color:var(--dim);min-width:55px}

/* ===== CALENDAR ===== */
.cal-row{display:flex;gap:2px;align-items:center;margin:2px 0}
.cal-row .cn{width:70px;font-size:.72em;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-cell{width:14px;height:10px;border-radius:2px}

/* ===== FIELD NOTEBOOK ===== */
.find-card{background:var(--card);border-radius:6px;padding:8px;margin:4px 0;border-left:4px solid;position:relative}
.find-card .find-date{color:var(--dim);font-size:.8em}
.find-card .find-sp{font-weight:700;font-size:1em}
.find-card .find-note{color:#aaa;font-size:.85em;font-style:italic;margin-top:2px}
.find-card .find-pos{color:var(--dim);font-size:.75em}
.find-del{position:absolute;top:6px;right:8px;color:var(--red);cursor:pointer;font-size:1em;opacity:.5;padding:4px}
.find-del:hover{opacity:1}

/* ===== FIND OVERLAY & MODAL ===== */
.find-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9990;display:none;align-items:center;justify-content:center;padding:12px}
.find-overlay.open{display:flex}
.find-modal{background:var(--panel);border-radius:12px;padding:16px;max-width:100%;width:100%;border:2px solid var(--accent);max-height:90vh;overflow-y:auto}
.find-modal h3{color:var(--accent);font-size:1.15em;margin-bottom:12px;text-align:center;font-weight:800}
.find-form label{display:block;font-size:.95em;color:var(--accent);margin:10px 0 4px;font-weight:600}
.find-form select,.find-form input,.find-form textarea{width:100%;background:#111825;border:1px solid #333;color:var(--text);border-radius:6px;padding:10px 12px;font-size:1em;font-family:inherit;min-height:44px}
.find-form textarea{resize:vertical;min-height:60px;line-height:1.4}
.find-gps-btn{width:100%;margin-bottom:8px;padding:10px;background:var(--accent);color:#000;border:none;border-radius:8px;font-weight:700;cursor:pointer;font-size:1em;min-height:48px}
.find-pos-display{font-size:.75em;color:var(--accent);background:#1a2235;padding:8px;border-radius:6px;margin-bottom:8px}
.find-btns{display:flex;gap:8px;margin-top:12px}
.find-btns button{flex:1;padding:12px;border:none;border-radius:6px;font-size:1em;font-weight:700;cursor:pointer;min-height:48px;transition:all .2s}
.find-save{background:var(--green);color:#000;font-weight:800}
.find-save:active{transform:scale(.98)}
.find-cancel{background:#3a3a4a;color:var(--text)}
.find-cancel:active{opacity:.8}

/* ===== PHOTO MODAL ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal-content{max-width:90vw;max-height:80vh;border-radius:8px}
.modal-close{position:fixed;top:12px;right:18px;color:#fff;font-size:2em;cursor:pointer;z-index:10000}

/* ===== MAP LEGENDS & POPUPS ===== */
.zone-legend{background:rgba(21,28,46,.92);padding:8px 10px;border-radius:8px;font-size:.8em;line-height:1.5;color:#ccc;max-width:240px;box-shadow:0 2px 8px rgba(0,0,0,.5)}
.zone-legend b{color:var(--accent)}
.zl-row{display:flex;align-items:center;gap:5px;margin:1px 0}
.zl-swatch{width:18px;height:10px;border-radius:3px;flex-shrink:0}
.map-legend{background:rgba(21,28,46,.92);padding:5px;border-radius:5px;font-size:.75em;line-height:1.5;color:#aaa}
.map-legend b{color:var(--accent)}
.lg-c{display:inline-block;width:12px;height:12px;border-radius:2px;vertical-align:middle;margin-right:3px;border:1px solid #444}
.myco-popup .leaflet-popup-content-wrapper{background:#151c2e;color:#e0e0e0;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.7);font-size:14px}
.myco-popup .leaflet-popup-content{margin:10px 12px}
.myco-popup .leaflet-popup-tip{background:#151c2e}
.myco-popup a.leaflet-popup-close-button{color:#888;font-size:20px;top:6px;right:8px}

/* ===== LEAFLET OVERRIDES ===== */
.leaflet-popup-content-wrapper{background:var(--panel)!important;color:var(--text)!important;border-radius:8px!important}
.leaflet-popup-tip{background:var(--panel)!important}
.leaflet-popup-content{font-size:.9em;line-height:1.35}
.leaflet-popup-content b{color:var(--accent)}
