:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0b100e;color:#edf0e7;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 18% 0%,rgba(83,107,86,.24),transparent 34%),linear-gradient(135deg,#0c1210,#151d19 48%,#0b100e)}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:default;opacity:.75}.app-shell{min-height:100vh;display:grid;grid-template-columns:72px 302px minmax(420px,1fr) 336px;background:#080c0a80}.nav-rail{display:flex;flex-direction:column;align-items:center;gap:14px;padding:18px 10px;background:#090d0c;border-right:1px solid rgba(237,240,231,.08)}.brand-mark,.rail-button{width:44px;height:44px;border-radius:8px;display:grid;place-items:center}.brand-mark{color:#f0b64c;background:linear-gradient(145deg,#22332b,#0f1513);box-shadow:inset 0 0 0 1px #f0b64c33;margin-bottom:10px}.rail-button{color:#b8c4b4;border:1px solid transparent;background:transparent}.rail-button:hover,.rail-button.active{color:#f4f0dc;border-color:#819a7759;background:#17221d}.rail-button.bottom{margin-top:auto}.library-panel,.inspector-panel{overflow:auto;background:#101714f0}.library-panel{padding:22px 18px;border-right:1px solid rgba(237,240,231,.09)}.panel-heading,.section-title,.topbar,.topbar-actions,.map-toolbar,.hike-row,.group-row,.shared-row,.group-create,.stats-strip{display:flex;align-items:center}.panel-heading,.topbar,.section-title{justify-content:space-between}.small-label{margin:0 0 4px;color:#91a08f;font-size:11px;font-weight:700;letter-spacing:0;text-transform:uppercase}h1{margin:0;font-size:24px;line-height:1.05;letter-spacing:0}.icon-button,.ghost-button,.primary-button,.map-toolbar button,.group-create button,.file-button{border:1px solid rgba(237,240,231,.12);border-radius:8px;color:#edf0e7;background:#17221d}.icon-button{width:38px;height:38px;display:grid;place-items:center}.icon-button.amber,.primary-button{color:#16140d;background:#f0b64c;border-color:#f0b64c}.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:22px 0}.metric-grid div,.stats-strip div,.invite-card{border:1px solid rgba(237,240,231,.09);border-radius:8px;background:#111a16;padding:12px;color:#94a390;font-size:12px}.metric-grid span,.stats-strip span{display:block;margin-bottom:3px;color:#f4f0dc;font-size:22px;font-weight:800}.auth-panel{display:grid;gap:8px;border:1px solid rgba(119,164,176,.28);border-radius:8px;background:#131f1cad;padding:12px;color:#aebaaa;font-size:12px}.auth-panel strong{color:#f4f0dc;font-size:13px}.auth-panel span{color:#91a08f}.auth-panel.signed-in{grid-template-columns:1fr auto;align-items:center}.auth-panel input{width:100%;height:36px;border:1px solid rgba(237,240,231,.12);border-radius:8px;color:#edf0e7;background:#0d1411;padding:0 10px;outline:none}.auth-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.auth-panel button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(237,240,231,.12);border-radius:8px;color:#edf0e7;background:#17221d;font-size:12px;font-weight:800}.auth-panel button:hover{border-color:#f0b64c73}.auth-message{color:#f0b64c!important;line-height:1.35}.section-title{margin:18px 0 10px;color:#dce3d5;font-size:12px;font-weight:800;letter-spacing:0;text-transform:uppercase}.hike-list,.group-list,.shared-list{display:grid;gap:8px}.hike-row,.group-row,.shared-row{width:100%;justify-content:space-between;gap:12px;border:1px solid rgba(237,240,231,.08);border-radius:8px;color:#edf0e7;background:#0b100e9e;padding:12px;text-align:left}.hike-row:hover,.hike-row.selected,.group-row:hover,.group-row.selected,.shared-row:hover,.shared-row.selected{border-color:#f0b64c80;background:#f0b64c17}.hike-row-main,.group-row span,.shared-row span{min-width:0;display:grid;gap:3px}.hike-row strong,.group-row strong,.shared-row strong{overflow:hidden;color:#f4f0dc;font-size:13px;white-space:nowrap;text-overflow:ellipsis}.hike-row small,.group-row small,.shared-row small,.hike-row-meta{color:#91a08f;font-size:12px}.hike-row-meta{display:flex;align-items:center;gap:2px;flex:0 0 auto}.groups-title{margin-top:24px}.group-create{gap:8px;margin-bottom:8px}.group-create input,.marker-editor input,.marker-editor textarea,.marker-editor select,.map-toolbar select,.title-input,.location-input{width:100%;border:1px solid rgba(237,240,231,.12);border-radius:8px;color:#edf0e7;background:#0d1411;outline:none}.group-create input{height:38px;padding:0 11px;font-size:13px}.group-create button{width:38px;height:38px;display:grid;place-items:center;flex:0 0 auto}.map-workspace{position:relative;min-width:0;display:grid;grid-template-rows:auto auto minmax(360px,1fr);padding:20px;overflow:hidden}.topbar{gap:18px;margin-bottom:14px}.title-input,.location-input{display:block;border:0;padding:0;background:transparent}.title-input{max-width:min(620px,48vw);color:#f4f0dc;font-size:28px;font-weight:850;line-height:1.12}.location-input{max-width:420px;margin-top:6px;color:#91a08f;font-size:13px}.topbar-actions{gap:8px;flex-wrap:wrap;justify-content:flex-end}.ghost-button,.primary-button,.map-toolbar button,.file-button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;font-size:13px;font-weight:800}.ghost-button:hover,.map-toolbar button:hover,.map-toolbar button.active{border-color:#6f9aa573;background:#20302c}.map-toolbar{z-index:2;gap:8px;margin-bottom:14px;flex-wrap:wrap}.map-toolbar select{width:auto;min-height:38px;padding:0 34px 0 12px;color:#dce3d5;font-size:13px;font-weight:700}.layer-button{margin-left:auto}.map-stage{position:relative;min-height:0;border:1px solid rgba(237,240,231,.1);border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#182a21b8,#101916f0),#101713;box-shadow:0 24px 80px #00000059}.map-stage.layer-trail{background:linear-gradient(135deg,#213828c7,#0d1614f0),#111812}.map-stage.layer-night{background:linear-gradient(135deg,#0f1c23db,#080c0df5),#0a1011}.trail-map{width:100%;height:100%;min-height:520px;display:block}.water-shape{fill:#3f748138}.ridge-line{fill:none;stroke:#d7decb2e;stroke-width:1.4;stroke-linecap:round;stroke-dasharray:1.4 2.2}.ridge-line.faint{opacity:.7;stroke-width:.9}.road-line{fill:none;stroke:#b8944f52;stroke-width:1.2;stroke-linecap:round}.road-line.thin{stroke-width:.72;opacity:.75}.active-route{fill:none;stroke:#f0b64c;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.route-point{fill:#f4f0dc;stroke:#121916;stroke-width:.7}.trail-map text{pointer-events:none;fill:#edf0e7;font-size:2.2px;font-weight:800;letter-spacing:0;paint-order:stroke;stroke:#080c0abf;stroke-width:.45px}.marker-pin{cursor:pointer}.marker-pin path{fill:#d88e37;stroke:#181d17;stroke-width:.65}.marker-pin circle:first-child{fill:#d88e373d}.marker-pin .marker-dot{fill:#111712}.marker-pin.selected path{fill:#77a4b0}.marker-pin.selected circle:first-child{fill:#77a4b047}.map-status{position:absolute;left:16px;right:16px;bottom:16px;display:flex;justify-content:space-between;gap:10px;color:#dce3d5;font-size:12px;font-weight:800;pointer-events:none}.map-status span{display:inline-flex;align-items:center;gap:7px;min-height:32px;border:1px solid rgba(237,240,231,.1);border-radius:8px;background:#090d0cbd;padding:0 10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.mobile-preview{position:absolute;right:34px;bottom:34px;width:132px;pointer-events:none}.phone-frame{border:1px solid rgba(237,240,231,.12);border-radius:16px;background:#0b100e;padding:8px;box-shadow:0 18px 45px #0000006b}.phone-map{position:relative;height:126px;border-radius:10px;overflow:hidden;background:linear-gradient(130deg,rgba(119,164,176,.28),transparent 42%),repeating-linear-gradient(140deg,rgba(237,240,231,.08) 0 1px,transparent 1px 14px),#17231d}.phone-map span{position:absolute;left:16px;top:72px;width:88px;height:3px;border-radius:99px;background:#f0b64c;transform:rotate(-26deg)}.phone-frame strong,.phone-frame small{display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.phone-frame strong{margin-top:8px;color:#f4f0dc;font-size:11px}.phone-frame small{color:#91a08f;font-size:10px}.inspector-panel{padding:20px 18px;border-left:1px solid rgba(237,240,231,.09)}.stats-strip{gap:8px}.stats-strip div{flex:1;min-width:0}.stats-strip span{font-size:17px}.inspector-section{margin-top:18px;border-top:1px solid rgba(237,240,231,.08);padding-top:2px}.photo-box{height:174px;border:1px solid rgba(237,240,231,.1);border-radius:8px;overflow:hidden;background:linear-gradient(135deg,#77a4b029,#f0b64c1a),#0d1411}.photo-box img{width:100%;height:100%;object-fit:cover;display:block}.photo-box div{height:100%;display:grid;place-items:center;align-content:center;gap:8px;color:#91a08f;font-size:13px;font-weight:700}.marker-editor label{display:grid;gap:7px;margin-top:12px;color:#aebaaa;font-size:12px;font-weight:800}.marker-editor input,.marker-editor select{height:38px;padding:0 11px}.marker-editor textarea{min-height:92px;resize:vertical;padding:10px 11px;line-height:1.45}.file-button{margin-top:12px}.file-button input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.empty-state{min-height:120px;display:grid;place-items:center;align-content:center;gap:8px;border:1px dashed rgba(237,240,231,.16);border-radius:8px;color:#91a08f;padding:18px;text-align:center;font-size:13px;font-weight:700}.empty-state.compact{min-height:68px}.invite-card{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.invite-card span{color:#91a08f;font-size:12px}.invite-card strong{color:#f0b64c;font-size:13px}@media(max-width:1180px){.app-shell{grid-template-columns:62px 272px minmax(360px,1fr)}.inspector-panel{grid-column:2 / -1;border-left:0;border-top:1px solid rgba(237,240,231,.09);display:grid;grid-template-columns:1fr 1fr;gap:18px}.stats-strip{grid-column:1 / -1}.trail-map{min-height:460px}}@media(max-width:820px){.app-shell{display:block}.nav-rail{position:sticky;top:0;z-index:5;flex-direction:row;justify-content:center;padding:10px;border-right:0;border-bottom:1px solid rgba(237,240,231,.08)}.rail-button.bottom,.brand-mark{margin:0}.library-panel,.inspector-panel,.map-workspace{padding:16px}.map-workspace{display:block}.topbar{align-items:flex-start;flex-direction:column}.title-input,.location-input{max-width:100%}.title-input{font-size:24px}.layer-button{margin-left:0}.trail-map{min-height:410px}.mobile-preview{display:none}.inspector-panel{display:block}}@media(max-width:520px){.nav-rail{justify-content:flex-start;overflow-x:auto}.topbar-actions,.map-toolbar{width:100%}.ghost-button,.primary-button,.map-toolbar button,.map-toolbar select{flex:1 1 auto}.map-status{align-items:flex-start;flex-direction:column}.stats-strip{align-items:stretch;flex-direction:column}}
