*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,Avenir,Helvetica,Arial,sans-serif;font-size:16px;line-height:24px;font-weight:400;color:#0f0f0f;background-color:#f6f6f6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{margin:0;padding:0;width:100vw;height:100vh;overflow:hidden}#map{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.left-toolbar{position:fixed;left:20px;top:20px;width:280px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000026;z-index:1000;padding:16px}.search-section{margin-bottom:20px}#search-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;outline:none;transition:border-color .3s}#search-input:focus{border-color:#396cd8}.favourites-section h3{font-size:16px;font-weight:600;margin-bottom:12px;color:#333}#favourites-list{display:flex;flex-direction:column;gap:8px}.favourite-item{padding:12px;background:#f8f8f8;border-radius:8px;cursor:pointer;transition:background .2s}.favourite-item:hover{background:#e8e8e8}.favourite-name{font-weight:600;font-size:14px;color:#333;margin-bottom:4px}.favourite-price{font-size:13px;color:#666}.bottom-toolbar{position:fixed;bottom:0;left:0;width:100%;height:60px;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -2px 8px #0000001a;z-index:1000;display:flex;justify-content:space-between;align-items:center;padding:0 24px 0 0}.toolbar-left{height:100%}.toolbar-left .logo{font-size:20px;font-weight:700;color:#396cd8;height:100%}.toolbar-right{display:flex;gap:12px}.icon-button{background:transparent;border:none;padding:8px;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s;color:#666}.icon-button:hover{background:#f0f0f0;color:#396cd8}.fuel-marker{background:#fff;border:2px solid #396cd8;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0003;position:relative;overflow:hidden}.fuel-marker:hover{transform:scale(1.1);z-index:1001}.marker-brand-logo{width:100%;height:100%;object-fit:cover;padding:10px!important}.marker-price-overlay{position:absolute;bottom:0;left:0;right:0;background:#fffffff2;color:#396cd8;font-size:11px;font-weight:700;padding:3px 0;text-align:center;border-bottom-left-radius:50%;border-bottom-right-radius:50%;box-shadow:0 -1px 3px #0000001a}.fuel-marker.no-logo{background:#fff;flex-direction:column;justify-content:center}.fuel-marker.no-logo .marker-price-overlay{position:static;background:transparent;box-shadow:none;font-size:12px;padding:0}.fuel-marker.cluster{width:50px;height:50px;font-size:13px;position:relative;background:linear-gradient(135deg,#396cd8,#24c8db);color:#fff;border-color:#fff;overflow:visible}.cluster-count{position:absolute;top:-5px;right:-5px;background:#ff6b6b;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid white}.cluster-popup{padding:8px}.cluster-popup h3{margin:0 0 12px;font-size:16px;color:#333}.cluster-stations-list{max-height:300px;overflow-y:auto}.cluster-station-item{display:flex;justify-content:space-between;padding:8px;border-bottom:1px solid #eee;gap:12px}.cluster-station-item:last-child{border-bottom:none}.cluster-station-name{flex:1;font-weight:500;color:#333}.cluster-station-price{font-weight:600;color:#396cd8;white-space:nowrap}.leaflet-top.leaflet-right{top:20px;right:20px;z-index:1001}.leaflet-control-zoom{box-shadow:0 2px 6px #0003;border-radius:8px;overflow:hidden}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){color:#f6f6f6;background-color:#2f2f2f}:root:not([data-theme=light]) .left-toolbar,:root:not([data-theme=light]) .bottom-toolbar{background:#1a1a1a;border-color:#333}:root:not([data-theme=light]) #search-input{background:#2f2f2f;color:#f6f6f6;border-color:#444}:root:not([data-theme=light]) .favourite-item{background:#2a2a2a;color:#f6f6f6}:root:not([data-theme=light]) .favourite-item:hover{background:#3a3a3a}:root:not([data-theme=light]) .favourite-name{color:#f6f6f6}:root:not([data-theme=light]) .favourite-price{color:#aaa}:root:not([data-theme=light]) .icon-button{color:#aaa}:root:not([data-theme=light]) .icon-button:hover{background:#2a2a2a;color:#24c8db}}:root[data-theme=dark]{color:#f6f6f6;background-color:#2f2f2f}:root[data-theme=dark] .left-toolbar,:root[data-theme=dark] .bottom-toolbar{background:#1a1a1a;border-color:#333}:root[data-theme=dark] #search-input{background:#2f2f2f;color:#f6f6f6;border-color:#444}:root[data-theme=dark] .favourite-item{background:#2a2a2a;color:#f6f6f6}:root[data-theme=dark] .favourite-item:hover{background:#3a3a3a}:root[data-theme=dark] .favourite-name{color:#f6f6f6}:root[data-theme=dark] .favourite-price{color:#aaa}:root[data-theme=dark] .icon-button{color:#aaa}:root[data-theme=dark] .icon-button:hover{background:#2a2a2a;color:#24c8db}.station-popup{font-family:Inter,Avenir,Helvetica,Arial,sans-serif;min-width:350px}.popup-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid #e0e0e0;margin-bottom:12px}.popup-brand-logo{width:50px;height:50px;object-fit:contain;border-radius:4px}.popup-title h3{margin:0;font-size:16px;font-weight:600;color:#333}.popup-title{display:flex;align-items:center;gap:8px;flex:1}.favorite-toggle{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:transform .2s;border-radius:4px}.favorite-toggle:hover{transform:scale(1.1);background:#0000000d}.favorite-toggle:active{transform:scale(.95)}.favorite-star{transition:all .2s;color:#666}.favorite-star.active,.favorite-toggle:hover .favorite-star{color:gold;stroke:gold}.popup-brand{margin:2px 0 0;font-size:13px;color:#666}.popup-content{display:grid;grid-template-columns:1fr 1fr;gap:16px}.popup-column h4{margin:0 0 8px;font-size:14px;font-weight:600;color:#333}.popup-fuel-price{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f0f0f0}.popup-fuel-price:last-child{border-bottom:none}.fuel-type{font-size:13px;color:#555}.fuel-price{font-size:13px;font-weight:600;color:#396cd8}.popup-detail-item{margin-bottom:12px}.popup-detail-item:last-child{margin-bottom:0}.popup-detail-item strong{display:block;font-size:12px;color:#666;margin-bottom:4px}.popup-detail-item p{margin:0;font-size:13px;color:#333;line-height:1.4}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .leaflet-popup-content-wrapper,:root:not([data-theme=light]) .leaflet-popup-tip{background:#1a1a1a;color:#f6f6f6}:root:not([data-theme=light]) .popup-header{border-bottom-color:#444}:root:not([data-theme=light]) .popup-title h3,:root:not([data-theme=light]) .popup-column h4,:root:not([data-theme=light]) .popup-detail-item p{color:#f6f6f6}:root:not([data-theme=light]) .popup-brand,:root:not([data-theme=light]) .fuel-type,:root:not([data-theme=light]) .popup-detail-item strong{color:#aaa}:root:not([data-theme=light]) .popup-fuel-price{border-bottom-color:#333}:root:not([data-theme=light]) .fuel-price{color:#24c8db}:root:not([data-theme=light]) .favorite-toggle:hover{background:#ffffff1a}:root:not([data-theme=light]) .favorite-star{color:#aaa}:root:not([data-theme=light]) .favorite-star.active{color:gold;stroke:gold}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 24px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#333}.close-btn{background:transparent;border:none;font-size:28px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.close-btn:hover{background:#f0f0f0;color:#333}.modal-body{margin-bottom:20px}.modal-footer{display:flex;justify-content:flex-end;gap:12px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#396cd8;color:#fff}.btn-primary:hover{background:#2d5ac0}.btn-secondary{background:#e0e0e0;color:#333}.btn-secondary:hover{background:#d0d0d0}.setting-group{margin-bottom:24px}.setting-group:last-child{margin-bottom:0}.setting-group label{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:8px}.setting-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;color:#333;cursor:pointer;outline:none;transition:border-color .3s}.setting-group select:focus{border-color:#396cd8}.setting-help{margin:8px 0 0;font-size:12px;color:#666}.radio-group{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.radio-label input[type=radio]{cursor:pointer}.radio-label span{font-size:14px;color:#333}#permission-dialog .modal-content h2{margin-bottom:16px}#permission-dialog .modal-content p{margin-bottom:12px;font-size:14px;line-height:1.6;color:#555}#permission-dialog .modal-content ul{margin:12px 0;padding-left:24px}#permission-dialog .modal-content li{margin-bottom:8px;font-size:14px;color:#555}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .modal-content{background:#1a1a1a}:root:not([data-theme=light]) .modal-header h2,:root:not([data-theme=light]) .setting-group label,:root:not([data-theme=light]) .radio-label span{color:#f6f6f6}:root:not([data-theme=light]) .close-btn{color:#aaa}:root:not([data-theme=light]) .close-btn:hover{background:#2a2a2a;color:#f6f6f6}:root:not([data-theme=light]) .btn-secondary{background:#2a2a2a;color:#f6f6f6}:root:not([data-theme=light]) .btn-secondary:hover{background:#3a3a3a}:root:not([data-theme=light]) .setting-group select{background:#2f2f2f;color:#f6f6f6;border-color:#444}:root:not([data-theme=light]) .setting-help,:root:not([data-theme=light]) #permission-dialog .modal-content p,:root:not([data-theme=light]) #permission-dialog .modal-content li{color:#aaa}}:root[data-theme=dark] .modal-content{background:#1a1a1a}:root[data-theme=dark] .modal-header h2,:root[data-theme=dark] .setting-group label,:root[data-theme=dark] .radio-label span{color:#f6f6f6}:root[data-theme=dark] .close-btn{color:#aaa}:root[data-theme=dark] .close-btn:hover{background:#2a2a2a;color:#f6f6f6}:root[data-theme=dark] .btn-secondary{background:#2a2a2a;color:#f6f6f6}:root[data-theme=dark] .btn-secondary:hover{background:#3a3a3a}:root[data-theme=dark] .setting-group select{background:#2f2f2f;color:#f6f6f6;border-color:#444}:root[data-theme=dark] .setting-help,:root[data-theme=dark] #permission-dialog .modal-content p,:root[data-theme=dark] #permission-dialog .modal-content li{color:#aaa}.popup-fuel-price.preferred{background:#e8f0fe;border-radius:4px;padding:8px 6px;margin:0 -6px}.popup-fuel-price.preferred .fuel-type{font-weight:600;color:#396cd8}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .popup-fuel-price.preferred{background:#1e3a5f}:root:not([data-theme=light]) .popup-fuel-price.preferred .fuel-type{color:#24c8db}}:root[data-theme=dark] .popup-fuel-price.preferred{background:#1e3a5f}:root[data-theme=dark] .popup-fuel-price.preferred .fuel-type{color:#24c8db}:root[data-theme=dark] .favorite-toggle:hover{background:#ffffff1a}:root[data-theme=dark] .favorite-star{color:#aaa}:root[data-theme=dark] .favorite-star.active{color:gold;stroke:gold}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;pointer-events:none}.toast{background:#fff;color:#333;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;width:350px;pointer-events:auto;display:flex;align-items:center;gap:12px;animation:slideIn .3s ease-out;transition:all .3s ease-out;margin-bottom:10px;max-height:200px;overflow:hidden}.toast.hiding{opacity:0;transform:translate(400px);max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0}@keyframes slideIn{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.toast-message{flex:1;font-size:14px;line-height:1.5}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:4px;color:#666;font-size:20px;line-height:1;opacity:.6;transition:opacity .2s}.toast-close:hover{opacity:1}.toast.success{border-left:4px solid #28a745}.toast.info{border-left:4px solid #396cd8}.toast.warning{border-left:4px solid #ffc107}.toast.error{border-left:4px solid #dc3545}.toast.loading{border-left:4px solid #396cd8}.toast.success .toast-icon{color:#28a745}.toast.info .toast-icon{color:#396cd8}.toast.warning .toast-icon{color:#ffc107}.toast.error .toast-icon{color:#dc3545}.toast.loading .toast-icon{color:#396cd8}.toast .spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root[data-theme=dark] .toast{background:#2d2d2d;color:#e0e0e0;box-shadow:0 4px 12px #00000080}:root[data-theme=dark] .toast-close{color:#999}.share-description{color:#666;font-size:14px;margin-bottom:20px;text-align:center}.share-options{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.share-option-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px;border:2px solid #e0e0e0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#333}@media(prefers-reduced-motion:reduce){.share-option-btn{transition:none}}.share-option-btn:hover{border-color:#396cd8;background:#f8f9ff;transform:translateY(-2px)}@media(prefers-reduced-motion:reduce){.share-option-btn:hover{transform:none}}.share-option-btn:focus{outline:2px solid #396cd8;outline-offset:2px;border-color:#396cd8;background:#f8f9ff}.share-option-btn:active{transform:translateY(0)}@media(prefers-reduced-motion:reduce){.share-option-btn:active{transform:none}}.share-icon{width:32px;height:32px}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .share-description{color:#aaa}:root:not([data-theme=light]) .share-option-btn{background:#2d2d2d;border-color:#444;color:#e0e0e0}:root:not([data-theme=light]) .share-option-btn:hover{border-color:#24c8db;background:#1e3a5f}:root:not([data-theme=light]) .share-option-btn:focus{outline:2px solid #24c8db;outline-offset:2px;border-color:#24c8db;background:#1e3a5f}}:root[data-theme=dark] .share-description{color:#aaa}:root[data-theme=dark] .share-option-btn{background:#2d2d2d;border-color:#444;color:#e0e0e0}:root[data-theme=dark] .share-option-btn:hover{border-color:#24c8db;background:#1e3a5f}:root[data-theme=dark] .share-option-btn:focus{outline:2px solid #24c8db;outline-offset:2px;border-color:#24c8db;background:#1e3a5f}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .cluster-popup h3{color:#e0e0e0}:root:not([data-theme=light]) .cluster-station-item{border-bottom-color:#444}:root:not([data-theme=light]) .cluster-station-name{color:#e0e0e0}:root:not([data-theme=light]) .cluster-station-price{color:#24c8db}}:root[data-theme=dark] .cluster-popup h3{color:#e0e0e0}:root[data-theme=dark] .cluster-station-item{border-bottom-color:#444}:root[data-theme=dark] .cluster-station-name{color:#e0e0e0}:root[data-theme=dark] .cluster-station-price{color:#24c8db}
