@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:300;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:400;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:500;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:600;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/ba9851c3c22cd980-s.woff2) format("woff2");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/21350d82a1f187e9-s.woff2) format("woff2");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/c5fe6dc8356a8c31-s.woff2) format("woff2");unicode-range:u+1f??}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/19cfc7226ec3afaa-s.woff2) format("woff2");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/df0a9ae256c0569c-s.woff2) format("woff2");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/8e9860b6e62d6359-s.woff2) format("woff2");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-family:__Inter_fa2f99;font-style:normal;font-weight:700;font-display:swap;src:url(/_next/static/media/e4af272ccee01ff0-s.p.woff2) format("woff2");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-family:__Inter_Fallback_fa2f99;src:local("Arial");ascent-override:90.49%;descent-override:22.56%;line-gap-override:0.00%;size-adjust:107.06%}.__className_fa2f99{font-family:__Inter_fa2f99,__Inter_Fallback_fa2f99;font-style:normal}*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--primary:#1b9e3e;--primary-dark:#157a30;--primary-light:#2fc955;--accent:#f0a500;--bg-dark:#0d1b2a;--bg-sidebar:#112240;--bg-card:#1a2f4a;--bg-surface:#1e3a5f;--text-primary:#e8edf3;--text-secondary:#89a;--text-muted:#5a6a7a;--danger:#e74c3c;--warning:#f39c12;--info:#3498db;--success:#27ae60;--radius:10px;--radius-lg:16px;--shadow:0 4px 20px rgba(0,0,0,.35);--shadow-lg:0 8px 40px rgba(0,0,0,.5);--sidebar-width:260px;--header-height:56px;--transition:.3s cubic-bezier(.4,0,.2,1);--font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}html{height:100%}body{font-family:var(--font);background:var(--bg-dark);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--primary-light);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font);cursor:pointer;border:none;outline:none}.app-shell{display:flex;min-height:100vh;width:100%;position:relative}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100%;background:var(--bg-sidebar);z-index:1000;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform var(--transition);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translateX(0)}.sidebar-header{padding:20px;gap:12px;border-bottom:1px solid hsla(0,0%,100%,.08)}.sidebar-header,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{width:42px;height:42px;background:var(--primary);border-radius:12px;justify-content:center;font-size:22px;flex-shrink:0}.sidebar-brand h1{font-size:17px;font-weight:700;color:var(--text-primary);line-height:1.2}.sidebar-brand small{font-size:11px;color:var(--text-muted);font-weight:400}.sidebar-nav{flex:1 1;padding:12px 0;overflow-y:auto}.sidebar-nav .nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:16px 20px 6px}.nav-item{display:flex;align-items:center;gap:14px;padding:12px 20px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition);cursor:pointer;border-left:3px solid transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none}.nav-item:hover{background:hsla(0,0%,100%,.05);color:var(--text-primary)}.nav-item.active{background:rgba(27,158,62,.12);color:var(--primary-light);border-left-color:var(--primary)}.nav-item i{width:20px;text-align:center;font-size:16px}.sidebar-footer{padding:16px 20px;border-top:1px solid hsla(0,0%,100%,.08);font-size:11px;color:var(--text-muted);text-align:center}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);z-index:999}.sidebar-overlay.visible{display:block}.main-content{flex:1 1;display:flex;flex-direction:column;min-height:100vh;width:100%}.app-header{height:var(--header-height);min-height:var(--header-height);background:var(--bg-sidebar);padding:0 16px;gap:12px;border-bottom:1px solid hsla(0,0%,100%,.06);z-index:100}.app-header,.btn-menu{display:flex;align-items:center}.btn-menu{background:none;color:var(--text-primary);font-size:22px;padding:6px;justify-content:center}.header-title{font-size:16px;font-weight:600;flex:1 1}.header-actions{display:flex;gap:8px}.btn-icon{background:hsla(0,0%,100%,.08);color:var(--text-primary);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background var(--transition)}.btn-icon:hover{background:hsla(0,0%,100%,.15)}.sections-container{position:relative;overflow:hidden}.section,.sections-container{flex:1 1;display:flex;flex-direction:column}.section{overflow-y:auto;min-height:0}.section.active{display:flex;flex-direction:column}.section-map{overflow:hidden}.map-wrapper{flex:1 1;position:relative}#map{width:100%;height:100%;z-index:1}.map-controls{position:absolute;top:12px;left:12px;right:12px;z-index:500;display:flex;gap:8px;flex-wrap:wrap;pointer-events:none;justify-content:space-between;align-items:flex-start}.map-controls>*{pointer-events:auto}.map-controls-left-group{display:flex;flex-direction:column;gap:8px;align-items:flex-start}.map-controls-right-group{display:flex;gap:8px;flex-shrink:0}.filter-bar{display:flex;gap:8px;flex:1 1;min-width:0}.filter-select{background:var(--bg-card);min-width:0;max-width:200px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238899aa' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding:8px 30px 8px 12px}.filter-select,.search-input{color:var(--text-primary);border:1px solid hsla(0,0%,100%,.12);border-radius:var(--radius);font-size:13px;font-family:var(--font);flex:1 1}.search-input{background:var(--bg-card);padding:8px 12px;min-width:120px;max-width:220px}.search-input::placeholder{color:var(--text-muted)}.btn-add-spot{background:var(--primary);color:#fff;font-weight:600;font-size:13px;padding:8px 16px;border-radius:var(--radius);display:flex;align-items:center;gap:6px;white-space:nowrap;transition:background var(--transition);box-shadow:0 2px 10px rgba(27,158,62,.4)}.btn-add-spot:hover{background:var(--primary-dark)}.btn-gps{position:absolute;bottom:calc(24px + env(safe-area-inset-bottom));right:16px;z-index:500;background:var(--bg-card);color:var(--text-primary);width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--shadow);transition:all var(--transition)}.btn-gps:hover{background:var(--bg-surface)}.add-spot-banner{display:none;position:absolute;bottom:0;left:0;right:0;z-index:600;background:var(--bg-card);border-top:2px solid var(--primary);padding:16px 16px calc(16px + env(safe-area-inset-bottom));border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-lg);flex-direction:column;gap:12px;max-height:80vh;overflow-y:auto}.add-spot-banner.visible{display:flex}.add-spot-banner h3{font-size:16px;display:flex;align-items:center;gap:8px}.add-spot-banner h3 i{color:var(--primary)}.form-help{font-size:12px;color:var(--text-muted);background:hsla(0,0%,100%,.04);padding:8px 12px;border-radius:8px;line-height:1.5}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{background:var(--bg-surface);color:var(--text-primary);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;padding:10px 12px;font-size:14px;font-family:var(--font);transition:border-color var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical;min-height:60px}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.form-coords{display:flex;gap:8px;align-items:center;font-size:12px;color:var(--text-muted);background:hsla(0,0%,100%,.03);padding:8px 10px;border-radius:8px}.form-coords i{color:var(--info)}.form-coords span{font-family:monospace;font-size:12px}.form-actions{display:flex;gap:10px}.btn-primary{background:var(--primary);color:#fff;font-weight:600;font-size:14px;padding:10px 20px;border-radius:8px;flex:1 1;transition:background var(--transition)}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:hsla(0,0%,100%,.08);color:var(--text-primary);font-weight:500;font-size:14px;padding:10px 20px;border-radius:8px;transition:background var(--transition)}.btn-secondary:hover{background:hsla(0,0%,100%,.15)}.spot-drawer{display:none;position:absolute;z-index:700;background:var(--bg-card);box-shadow:var(--shadow-lg);overflow-y:auto}.spot-drawer.visible{display:flex;flex-direction:column}.spot-drawer{bottom:0;left:0;right:0;max-height:70vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:2px solid var(--primary)}.drawer-handle{width:40px;height:4px;background:hsla(0,0%,100%,.2);border-radius:2px;margin:10px auto 4px;flex-shrink:0}.drawer-header{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 16px 0}.drawer-header h2{font-size:18px;font-weight:700;flex:1 1}.btn-close-drawer{background:hsla(0,0%,100%,.08);color:var(--text-secondary);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.drawer-body{padding:12px 16px calc(20px + env(safe-area-inset-bottom))}.spot-type-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(27,158,62,.15);color:var(--primary-light);font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;margin-bottom:12px}.spot-info-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid hsla(0,0%,100%,.05)}.spot-info-row:last-child{border-bottom:none}.spot-info-row i{color:var(--text-muted);width:18px;text-align:center;margin-top:2px}.spot-info-row .info-content{flex:1 1}.spot-info-row .info-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.spot-info-row .info-value{font-size:14px;color:var(--text-primary);line-height:1.4}.fish-tags{display:flex;flex-wrap:wrap;gap:6px}.fish-tag{background:rgba(52,152,219,.15);color:var(--info);font-size:12px;font-weight:500;padding:3px 10px;border-radius:20px}.drawer-actions{display:flex;gap:8px;padding:12px 16px 16px;border-top:1px solid hsla(0,0%,100%,.06)}.btn-drawer-action{flex:1 1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;border-radius:8px;font-size:13px;font-weight:500;transition:background var(--transition)}.btn-favorite{background:rgba(240,165,0,.12);color:var(--accent)}.btn-favorite:hover{background:rgba(240,165,0,.22)}.btn-favorite.active{background:rgba(240,165,0,.3)}.btn-share{background:rgba(52,152,219,.12);color:var(--info)}.btn-share:hover{background:rgba(52,152,219,.22)}.btn-directions{background:rgba(27,158,62,.12);color:var(--primary-light)}.btn-directions:hover{background:rgba(27,158,62,.22)}.section-content{padding:20px 16px;flex:1 1}.section-hero{text-align:center;padding:40px 20px}.section-hero .hero-icon{font-size:48px;margin-bottom:16px;opacity:.7}.section-hero h2{font-size:22px;font-weight:700;margin-bottom:8px}.section-hero p{color:var(--text-secondary);font-size:14px;max-width:320px;margin:0 auto;line-height:1.5}.placeholder-card{background:var(--bg-card);border-radius:var(--radius);padding:20px;margin-bottom:12px;border:1px solid hsla(0,0%,100%,.06)}.placeholder-card h3{font-size:15px;margin-bottom:8px;display:flex;align-items:center;gap:8px}.placeholder-card p{font-size:13px;color:var(--text-secondary);line-height:1.5}.spots-list{display:flex;flex-direction:column;gap:10px}.spot-card{background:var(--bg-card);border-radius:var(--radius);padding:14px 16px;border:1px solid hsla(0,0%,100%,.06);cursor:pointer;transition:border-color var(--transition),background var(--transition)}.spot-card:hover{border-color:rgba(27,158,62,.3);background:var(--bg-surface)}.spot-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.spot-card-title{font-size:15px;font-weight:600}.spot-card-type{font-size:11px;background:rgba(27,158,62,.12);color:var(--primary-light);padding:2px 8px;border-radius:12px;font-weight:500}.spot-card-meta{font-size:12px;color:var(--text-muted);display:flex;gap:12px;flex-wrap:wrap}.spot-card-meta span{display:flex;align-items:center;gap:4px}.empty-state{text-align:center;padding:60px 20px}.empty-state i{font-size:56px;color:var(--text-muted);margin-bottom:16px}.empty-state h3{font-size:18px;margin-bottom:8px}.empty-state p{color:var(--text-secondary);font-size:13px;max-width:280px;margin:0 auto;line-height:1.5}.toast-container{position:fixed;bottom:calc(85px + env(safe-area-inset-bottom));left:16px;right:16px;transform:none;z-index:9999;flex-direction:column;pointer-events:none}.toast,.toast-container{display:flex;gap:8px;align-items:center}.toast{background:var(--bg-card);color:var(--text-primary);padding:12px 20px;border-radius:var(--radius);font-size:14px;box-shadow:var(--shadow-lg);border-left:3px solid var(--primary);animation:toastIn .3s ease,toastOut .3s ease 2.7s;animation-fill-mode:forwards;max-width:100%;pointer-events:auto}.toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--danger)}.toast.warning{border-left-color:var(--warning)}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.profile-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;text-align:center;border:1px solid hsla(0,0%,100%,.06);margin-bottom:16px}.profile-avatar{width:80px;height:80px;background:var(--bg-surface);border-radius:50%;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--text-muted)}.profile-card h2{font-size:18px;margin-bottom:4px}.profile-card p{font-size:13px;color:var(--text-secondary)}.profile-stats{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:12px;gap:12px;margin-top:20px}.stat-box{background:hsla(0,0%,100%,.04);padding:12px 8px;border-radius:8px}.stat-box .stat-num{font-size:22px;font-weight:700;color:var(--primary-light)}.stat-box .stat-label{font-size:11px;color:var(--text-muted);margin-top:2px}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid hsla(0,0%,100%,.2);border-top:2px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.leaflet-container{background:var(--bg-dark)!important;font-family:var(--font)!important}.custom-pin,.custom-pin .pin-inner{display:flex;align-items:center;justify-content:center}.custom-pin .pin-inner{width:32px;height:32px;background:var(--primary);border:3px solid #fff;border-radius:50% 50% 50% 0;transform:rotate(-45deg);box-shadow:0 2px 8px rgba(0,0,0,.4)}.custom-pin .pin-inner i{transform:rotate(45deg);color:#fff;font-size:14px}.draft-pin .pin-inner{background:var(--accent);animation:pulse 1.5s ease infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 0 rgba(240,165,0,.4)}50%{box-shadow:0 0 0 12px rgba(240,165,0,0)}}.leaflet-popup-content-wrapper{color:var(--text-primary)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow)!important;border:1px solid hsla(0,0%,100%,.1)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:var(--bg-card)!important}.leaflet-popup-content{margin:12px!important;font-family:var(--font)!important;font-size:13px!important}@media (min-width:768px){.spot-drawer{top:0;bottom:0;left:auto;right:0;max-height:none;width:380px;border-radius:0;border-top:none;border-left:2px solid var(--primary)}.drawer-handle{display:none}.map-controls{left:16px;right:400px;top:16px}.add-spot-banner{right:auto;left:0;width:380px;border-radius:0}}@media (min-width:1024px){.filter-bar{max-width:500px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.12);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.2)}.gps-search-overlay{display:none;position:absolute;top:0;left:0;right:0;bottom:0;z-index:550;background:rgba(13,27,42,.85);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);align-items:center;justify-content:center;flex-direction:column}.gps-search-overlay.visible{display:flex}.gps-search-content{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.gps-search-content i{font-size:40px;color:var(--info);animation:gpsBounce 1.5s ease infinite}.gps-search-content p{font-size:16px;font-weight:600;color:var(--text-primary)}.gps-search-content span{font-size:13px;color:var(--text-muted)}.gps-search-pulse{position:absolute;width:100px;height:100px;border-radius:50%;border:2px solid var(--info);animation:gpsPulseRing 2s ease-out infinite;opacity:0}@keyframes gpsBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes gpsPulseRing{0%{transform:scale(.5);opacity:.6}to{transform:scale(2.5);opacity:0}}.gps-indicator-wrapper{margin:0}.gps-status{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border-radius:8px;font-size:13px;background:hsla(0,0%,100%,.04)}.gps-status-header{display:flex;align-items:center;gap:8px}.gps-status-header i{font-size:14px}.gps-accuracy-label{font-weight:600;font-family:monospace;font-size:13px}.gps-quality-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px;margin-left:auto}.gps-quality-badge-sm{font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px;text-transform:uppercase;letter-spacing:.3px;margin-left:6px}.gps-progress-bar{width:100%;height:4px;background:hsla(0,0%,100%,.08);border-radius:2px;overflow:hidden}.gps-progress-fill{height:100%;border-radius:2px;transition:width .5s ease,background .5s ease;min-width:4px}.gps-excellent .gps-status-header i{color:#4caf50}.gps-good .gps-status-header i{color:#8bc34a}.gps-ok .gps-status-header i{color:#ff9800}.gps-low .gps-status-header i{color:#f44336}.gps-manual{flex-direction:row;align-items:center;gap:8px}.gps-manual i{color:var(--accent);font-size:14px}.gps-manual span,.gps-searching{color:var(--text-secondary)}.gps-searching{flex-direction:row;align-items:center;gap:8px}.gps-tip{color:var(--warning);display:flex;align-items:center;gap:6px;padding-top:2px}.gps-tip,.gps-tip i{font-size:11px}.gps-actions-row{display:flex;gap:8px}.btn-improve-gps{display:inline-flex;align-items:center;gap:6px;background:var(--info);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition)}.btn-improve-gps:hover{background:#2980d9;transform:translateY(-1px)}.btn-improve-gps:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.char-hint{font-weight:400;font-size:11px;color:var(--text-muted);text-transform:none;letter-spacing:0}.weather-location-bar{display:flex;align-items:center;gap:8px;background:var(--bg-card);padding:10px 14px;border-radius:var(--radius);margin-bottom:16px;border:1px solid hsla(0,0%,100%,.06);font-size:13px;color:var(--text-secondary)}.weather-location-bar i{color:var(--primary);font-size:14px}.weather-location-bar span{flex:1 1}.btn-change-loc{background:hsla(0,0%,100%,.08);color:var(--text-primary);font-size:12px;font-weight:500;padding:5px 10px;border-radius:6px;display:flex;align-items:center;gap:4px;white-space:nowrap;transition:background var(--transition);font-family:var(--font)}.btn-change-loc:hover{background:hsla(0,0%,100%,.15)}.weather-current{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;border:1px solid hsla(0,0%,100%,.06);margin-bottom:16px}.weather-current-main{text-align:center;padding-bottom:16px;border-bottom:1px solid hsla(0,0%,100%,.06);margin-bottom:16px}.weather-icon-big{font-size:56px;line-height:1;margin-bottom:4px}.weather-temp-big{font-size:52px;font-weight:700;line-height:1.1;color:var(--text-primary)}.weather-desc{font-size:16px;color:var(--text-secondary);margin-top:2px}.weather-feels{font-size:13px;color:var(--text-muted);margin-top:4px}.weather-details-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.weather-detail{background:hsla(0,0%,100%,.04);padding:10px 8px;border-radius:8px;text-align:center}.weather-detail i{font-size:14px;color:var(--info);margin-bottom:4px;display:block}.weather-detail .detail-val{display:block;font-size:14px;font-weight:600;color:var(--text-primary)}.weather-detail .detail-label{display:block;font-size:10px;color:var(--text-muted);margin-top:2px}@media (max-width:400px){.weather-details-grid{grid-template-columns:repeat(2,1fr)}}.weather-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:8px;margin:20px 0 12px;padding-bottom:8px;border-bottom:1px solid hsla(0,0%,100%,.06)}.weather-section-title i{color:var(--primary);font-size:13px}.hourly-scroll{display:flex;gap:2px;overflow-x:auto;padding-bottom:8px;-webkit-overflow-scrolling:touch}.hourly-item{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:58px;padding:8px 4px;background:var(--bg-card);border-radius:8px;border:1px solid hsla(0,0%,100%,.04)}.hourly-time{font-size:11px;color:var(--text-muted);font-weight:500}.hourly-icon{font-size:20px}.hourly-temp{font-size:13px;font-weight:600;color:var(--text-primary)}.hourly-rain{font-size:10px;color:var(--info)}.daily-list{display:flex;flex-direction:column;gap:6px}.daily-card{display:flex;align-items:center;gap:12px;background:var(--bg-card);padding:12px 14px;border-radius:var(--radius);border:1px solid hsla(0,0%,100%,.04)}.daily-day{min-width:70px}.daily-name{display:block;font-size:13px;font-weight:600;color:var(--text-primary)}.daily-date{display:block;font-size:11px;color:var(--text-muted)}.daily-icon{font-size:24px;min-width:32px;text-align:center}.daily-temps{min-width:55px;text-align:center}.temp-max{display:block;font-size:15px;font-weight:700;color:var(--text-primary)}.temp-min{display:block}.daily-info,.temp-min{font-size:11px;color:var(--text-muted)}.daily-info{flex:1 1;display:flex;gap:10px;flex-wrap:wrap}.daily-info i{color:var(--text-muted);margin-right:2px}.weather-credit{text-align:center;padding:16px 0;font-size:11px;color:var(--text-muted)}.weather-credit a{color:var(--info)}.moon-current{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:24px;border:1px solid hsla(0,0%,100%,.06);margin-bottom:16px}.moon-canvas{flex-shrink:0;border-radius:50%}.moon-info{flex:1 1}.moon-phase-name{font-size:20px;font-weight:700;margin-bottom:6px}.moon-illumination{font-size:14px;color:var(--text-secondary);margin-bottom:2px}.moon-age{font-size:13px;color:var(--text-muted)}@media (max-width:400px){.moon-current{flex-direction:column;text-align:center}}.fishing-indicator{margin-bottom:16px}.fishing-quality{display:flex;align-items:flex-start;gap:12px;background:var(--bg-card);padding:14px 16px;border-radius:var(--radius);border-left:3px solid var(--primary)}.fishing-quality>i{font-size:20px;margin-top:2px;flex-shrink:0}.fishing-quality-label{display:block;font-size:14px;color:var(--text-primary);margin-bottom:4px}.fishing-tip{font-size:12px;color:var(--text-secondary);line-height:1.5;margin:0}.upcoming-phases{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px;margin-bottom:8px}@media (min-width:600px){.upcoming-phases{grid-template-columns:repeat(4,1fr)}}.phase-card{background:var(--bg-card);padding:12px;border-radius:var(--radius);text-align:center;border:1px solid hsla(0,0%,100%,.04)}.phase-emoji{font-size:28px;display:block;margin-bottom:4px}.phase-name{display:block;font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.phase-date{display:block;font-size:11px;color:var(--text-secondary)}.phase-days{display:block;font-size:10px;color:var(--text-muted);margin-top:2px}.moon-calendar{background:var(--bg-card);border-radius:var(--radius);padding:12px;border:1px solid hsla(0,0%,100%,.04)}.cal-header{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:2px;gap:2px;margin-bottom:4px}.cal-header span{text-align:center;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;padding:4px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:2px;gap:2px}.cal-cell{text-align:center;padding:6px 2px;border-radius:6px;min-height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;cursor:default;transition:background var(--transition)}.cal-cell:hover:not(.empty){background:hsla(0,0%,100%,.06)}.cal-cell.today{background:rgba(27,158,62,.15);border:1px solid var(--primary)}.cal-cell.empty{pointer-events:none}.cal-day{font-size:11px;font-weight:500;color:var(--text-secondary)}.cal-moon{font-size:14px}.tide-current{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;border:1px solid hsla(0,0%,100%,.06);margin-bottom:16px}.tide-sea-state{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid hsla(0,0%,100%,.06);border-left:3px solid var(--primary);padding-left:12px}.tide-state-icon{font-size:28px}.tide-state-label{font-size:12px;color:var(--text-muted)}.tide-state-value{font-size:18px;font-weight:700}.tide-chart-container{background:var(--bg-card);border-radius:var(--radius);padding:12px;border:1px solid hsla(0,0%,100%,.04);margin-bottom:16px}.tide-chart-container canvas{width:100%;display:block}.tide-hourly-item{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:44px;padding:8px 4px;background:var(--bg-card);border-radius:8px;border:1px solid hsla(0,0%,100%,.04)}.tide-bar-container{width:20px;height:40px;background:hsla(0,0%,100%,.04);border-radius:4px;display:flex;align-items:flex-end;overflow:hidden}.tide-bar{width:100%;border-radius:4px 4px 0 0;transition:height .3s ease;min-height:2px}.drawer-extra-actions{display:flex;gap:6px;padding:0 16px 8px;flex-wrap:wrap}.btn-drawer-mini{background:hsla(0,0%,100%,.06);color:var(--text-secondary);font-size:11px;padding:5px 10px;border-radius:6px;display:flex;align-items:center;gap:4px;white-space:nowrap;transition:all var(--transition);font-family:var(--font)}.btn-drawer-mini:hover{background:hsla(0,0%,100%,.12);color:var(--text-primary)}.sidebar-auth{padding:12px 16px;border-top:1px solid hsla(0,0%,100%,.08)}.sidebar-user{gap:8px}.sidebar-user,.sidebar-user-info{display:flex;flex-direction:column}.sidebar-user-info{gap:2px}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.sidebar-user-email,.sidebar-user-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:11px;color:var(--text-muted)}.btn-sidebar-action{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font);background:hsla(0,0%,100%,.06);color:var(--text-secondary);transition:all var(--transition);width:100%;justify-content:center}.btn-sidebar-action:hover{background:hsla(0,0%,100%,.12);color:var(--text-primary)}.btn-sidebar-action.btn-login{background:rgba(27,158,62,.15);color:var(--primary-light)}.btn-sidebar-action.btn-login:hover{background:rgba(27,158,62,.3)}.btn-header-login{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;font-size:13px;font-weight:600;font-family:var(--font);background:var(--primary);color:#fff;transition:background var(--transition);white-space:nowrap}.btn-header-login:hover{background:var(--primary-dark)}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;border:1px solid hsla(0,0%,100%,.06);margin-bottom:16px;display:flex;flex-direction:column;gap:16px}.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;font-family:var(--font);background:#fff;color:#333;transition:all var(--transition);box-shadow:0 2px 8px rgba(0,0,0,.15)}.btn-google:hover{background:#f1f3f5;transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.btn-google:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-google i{font-size:18px;color:#4285f4}.login-divider{display:flex;align-items:center;gap:12px;margin:0;color:var(--text-muted);font-size:12px}.login-divider:after,.login-divider:before{content:"";flex:1 1;height:1px;background:hsla(0,0%,100%,.1)}.btn-text{display:block;width:100%;text-align:center;padding:10px;font-size:13px;color:var(--primary-light);background:none;font-family:var(--font);transition:color var(--transition);margin-top:0}.btn-text:hover{color:var(--primary);text-decoration:underline}.login-skip{text-align:center;padding:12px 0}.login-skip .btn-secondary{display:inline-flex;align-items:center;gap:8px}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-primary:disabled:hover{background:var(--primary)}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:8px;gap:8px;margin-bottom:8px}@media (min-width:600px){.template-grid{grid-template-columns:repeat(4,1fr)}}.template-card{background:var(--bg-card);border:1px solid hsla(0,0%,100%,.06);border-radius:var(--radius);padding:14px 10px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all var(--transition);font-family:var(--font);color:var(--text-primary)}.template-card:hover{border-color:rgba(27,158,62,.3);background:var(--bg-surface);transform:translateY(-2px)}.template-icon{font-size:28px}.template-name{font-size:12px;font-weight:600;text-align:center}.template-count{font-size:10px;color:var(--text-muted)}.checklist-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.checklist-detail-header h2{flex:1 1;font-size:18px;font-weight:700}.checklist-progress{display:flex;align-items:center;gap:12px;background:var(--bg-card);padding:12px 16px;border-radius:var(--radius);border:1px solid hsla(0,0%,100%,.06)}.checklist-progress-bar{flex:1 1;height:8px;background:hsla(0,0%,100%,.08);border-radius:4px;overflow:hidden}.checklist-progress-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .4s ease;min-width:2px}.checklist-progress-text{font-size:13px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.checklist-add-row{display:flex;gap:8px;margin-bottom:12px}.checklist-add-row input{flex:1 1;background:var(--bg-surface);color:var(--text-primary);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;padding:10px 12px;font-size:14px;font-family:var(--font)}.checklist-add-row input:focus{border-color:var(--primary);outline:none}.btn-sm{padding:8px 14px;font-size:13px}.checklist-items{display:flex;flex-direction:column;gap:4px}.checklist-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-card);border-radius:8px;border:1px solid hsla(0,0%,100%,.04);cursor:pointer;transition:all var(--transition);font-size:14px}.checklist-item:hover{background:var(--bg-surface)}.checklist-item.checked .checklist-item-label{text-decoration:line-through;color:var(--text-muted)}.checklist-item input[type=checkbox]{display:none}.checkmark{font-size:18px;color:var(--text-muted);flex-shrink:0;transition:color var(--transition)}.checklist-item.checked .checkmark{color:var(--primary)}.checklist-item-label{flex:1 1;font-size:14px;color:var(--text-primary);transition:all var(--transition)}.checklist-items-edit{display:flex;flex-direction:column;gap:4px;margin-top:8px;margin-bottom:8px}.checklist-item-edit{justify-content:space-between;gap:8px;padding:8px 12px;background:var(--bg-card);border-radius:8px;border:1px solid hsla(0,0%,100%,.04);color:var(--text-primary)}.btn-icon-sm,.checklist-item-edit{display:flex;align-items:center;font-size:13px}.btn-icon-sm{background:none;color:var(--text-muted);padding:4px;justify-content:center;transition:color var(--transition)}.btn-icon-sm:hover{color:var(--danger)}.poi-panel{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;border:1px solid hsla(0,0%,100%,.06);margin-bottom:12px}.poi-controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.poi-controls select{background:var(--bg-surface);color:var(--text-primary);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;padding:8px 12px;font-size:13px;font-family:var(--font)}.poi-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:500;background:hsla(0,0%,100%,.06);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);font-family:var(--font);border:1px solid transparent}.poi-chip.active{background:rgba(27,158,62,.15);color:var(--primary-light);border-color:rgba(27,158,62,.3)}.poi-chip:hover{background:hsla(0,0%,100%,.1)}.poi-list{display:flex;flex-direction:column;gap:6px}.poi-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:hsla(0,0%,100%,.03);border-radius:8px;border:1px solid hsla(0,0%,100%,.04);cursor:pointer;transition:all var(--transition)}.poi-item:hover{background:hsla(0,0%,100%,.06);border-color:rgba(27,158,62,.2)}.poi-item-icon{width:36px;height:36px;background:rgba(52,152,219,.12);color:var(--info);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.poi-item-info{flex:1 1;min-width:0}.poi-item-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.poi-item-category{font-size:11px;color:var(--text-muted)}.poi-item-distance{font-size:12px;font-weight:600;color:var(--info);white-space:nowrap}.btn-primary i,.btn-secondary i{margin-right:4px}.flex-center{display:flex;align-items:flex-start;justify-content:center;padding-top:5vh;padding-bottom:5vh}.profile-avatar img{border-radius:50%;object-fit:cover}.header-hamburger{background:none;color:var(--text-primary);font-size:22px;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background var(--transition);flex-shrink:0}.header-hamburger:hover{background:hsla(0,0%,100%,.08)}.header-hamburger:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);z-index:1099;opacity:0;pointer-events:none;transition:opacity var(--transition);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer-overlay.visible{opacity:1;pointer-events:auto}.drawer-nav{position:fixed;top:0;left:0;width:280px;max-width:85vw;height:100%;background:var(--bg-sidebar);z-index:1100;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform var(--transition);box-shadow:var(--shadow-lg)}.drawer-nav.open{transform:translateX(0)}@media (prefers-reduced-motion:reduce){.drawer-nav,.drawer-overlay{transition:none}}.drawer-nav-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid hsla(0,0%,100%,.08);flex-shrink:0}.drawer-nav-brand{display:flex;align-items:center;gap:12px}.drawer-nav-logo{width:40px;height:40px;background:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.drawer-nav-brand h2{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.2}.drawer-nav-brand small{font-size:11px;color:var(--text-muted);font-weight:400}.drawer-close-btn{background:none;color:var(--text-secondary);font-size:18px;padding:6px 8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.drawer-close-btn:hover{background:hsla(0,0%,100%,.1);color:var(--text-primary)}.drawer-close-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.drawer-nav-body{flex:1 1;padding:12px 0;overflow-y:auto}.drawer-nav-group+.drawer-nav-group{margin-top:4px}.drawer-nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);padding:16px 20px 6px}.drawer-nav-item{display:flex;align-items:center;gap:14px;padding:12px 20px;color:var(--text-secondary);font-size:14px;font-weight:500;transition:all var(--transition);cursor:pointer;border-left:3px solid transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:100%;background:none;text-align:left;font-family:var(--font)}.drawer-nav-item:hover{background:hsla(0,0%,100%,.05);color:var(--text-primary)}.drawer-nav-item.active{background:rgba(27,158,62,.12);color:var(--primary-light);border-left-color:var(--primary)}.drawer-nav-item:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.drawer-nav-item i{width:20px;text-align:center;font-size:16px}.drawer-nav-lock{font-size:10px!important;margin-left:auto;opacity:.5}.drawer-nav-auth{padding:12px 16px;border-top:1px solid hsla(0,0%,100%,.08);flex-shrink:0}.drawer-nav-user{display:flex;flex-direction:column;gap:8px}.drawer-nav-user-info{display:flex;flex-direction:column;gap:2px}.drawer-nav-user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.drawer-nav-user-email,.drawer-nav-user-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-nav-user-email{font-size:11px;color:var(--text-muted)}.drawer-nav-auth-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:500;font-family:var(--font);background:hsla(0,0%,100%,.06);color:var(--text-secondary);transition:all var(--transition);width:100%;justify-content:center}.drawer-nav-auth-btn:hover{background:hsla(0,0%,100%,.12);color:var(--text-primary)}.drawer-nav-login-btn{background:rgba(27,158,62,.15);color:var(--primary-light)}.drawer-nav-login-btn:hover{background:rgba(27,158,62,.3)}.drawer-nav-footer{padding:16px 20px;border-top:1px solid hsla(0,0%,100%,.08);font-size:11px;color:var(--text-muted);text-align:center;flex-shrink:0}.admin-page-layout .section-content{padding:0}.section-hero.short{padding:24px;border-bottom:1px solid hsla(0,0%,100%,.08)}.admin-container{display:flex;flex-direction:column}.admin-sidebar{flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid hsla(0,0%,100%,.08)}.admin-sidebar nav{display:flex;padding:12px;gap:8px;overflow-x:auto}.admin-sidebar button{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;color:var(--text-secondary);background-color:transparent;white-space:nowrap;transition:all var(--transition)}.admin-sidebar button:hover{background-color:hsla(0,0%,100%,.05);color:var(--text-primary)}.admin-sidebar button.active{background-color:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(27,158,62,.4)}.admin-content{flex:1 1;padding:16px;min-width:0}.content-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08);overflow:hidden}.content-card-header{padding:20px 24px;border-bottom:1px solid hsla(0,0%,100%,.08)}.content-card-header h3{font-size:18px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:10px}.content-card-header p{font-size:13px;color:var(--text-secondary);line-height:1.5}.content-card-body{padding:24px;display:flex;flex-direction:column;gap:20px}.form-group.stacked{flex-direction:column;gap:12px}.form-group.stacked input{width:100%}.user-details-card{margin-top:12px}.role-badge{display:inline-block;padding:3px 10px;font-size:12px;font-weight:600;border-radius:20px;color:#fff}.role-badge.role-user{background-color:var(--info)}.role-badge.role-admin{background-color:var(--danger)}.role-badge.role-influencer{background-color:var(--accent)}.filter-pills{display:flex;gap:8px;padding:8px;background-color:hsla(0,0%,100%,.05);border-radius:12px}.filter-pills button{flex:1 1;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-secondary);background-color:transparent;transition:all var(--transition)}.filter-pills button:hover{background-color:hsla(0,0%,100%,.08);color:var(--text-primary)}.filter-pills button.active{background-color:var(--bg-surface);color:var(--text-primary);box-shadow:0 1px 4px rgba(0,0,0,.2)}.item-card-list{gap:12px}.item-card,.item-card-list{display:flex;flex-direction:column}.item-card{background:var(--bg-surface);border-radius:var(--radius);border:1px solid hsla(0,0%,100%,.1)}.item-card-body{padding:16px;flex:1 1}.item-card .item-title{font-size:15px;font-weight:600;margin-bottom:4px}.item-card .item-subtitle{font-size:13px;color:var(--text-muted)}.item-card-footer{padding:12px 16px;background-color:rgba(0,0,0,.15);border-top:1px solid hsla(0,0%,100%,.1);display:flex;align-items:center;justify-content:space-between}.item-card-footer .btn-group{display:flex;gap:8px}.btn-sm i{margin-right:6px}.btn-sm.btn-success{background-color:var(--success)}.btn-sm.btn-danger{background-color:var(--danger)}.btn-sm.btn-warning{background-color:var(--warning);color:#fff}@media (min-width:768px){.admin-container{flex-direction:row;height:100%}.admin-sidebar{width:240px;border-right:1px solid hsla(0,0%,100%,.08)}.admin-sidebar nav{flex-direction:column;padding:16px}.admin-content{padding:24px}.form-group.stacked{flex-direction:row;align-items:center}.form-group.stacked input{max-width:350px}.item-card{flex-direction:row;align-items:center}.item-card-footer{border-top:none;border-left:1px solid hsla(0,0%,100%,.1);background:none;width:auto}}