:root{--color-ok:#1d9e75;--color-warn:#ef9f27;--color-no:#e24b4a;--color-brand-primary:#4cbfa6;--color-brand-sun:#f0dc4e;--color-status-ok-bg:#4cbfa61f;--color-status-warn-bg:#f0dc4e1f;--color-status-no-bg:#e8705a1f;--status-ok-raw:76, 191, 166;--status-warn-raw:240, 220, 78;--status-no-raw:232, 112, 90;--status-ok-accent:#6eecd4;--status-warn-accent:#ffe55a;--status-no-accent:#ff8b7a;--card-radius:14px;--bg:#0f1117;--bg-card:#1a1d27;--border:#2a2d3a;--text:#c8ccd8;--text-muted:#6b7080;--text-heading:#eef0f6;--skeleton-base:#ffffff0f;--skeleton-shine:#ffffff1f;--sans:system-ui, "Segoe UI", Roboto, sans-serif;font:16px/150% var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[data-theme=light]{--skeleton-base:#0000000f;--skeleton-shine:#0000001a;--bg:#f5f5f0;--bg-card:#fff;--border:#e0e0d8;--text:#3a3a3a;--text-muted:#888;--text-heading:#1a1a1a;color:#1a1a1a;background:#f5f5f0}[data-theme=light] .today-hero__encart{background:#00000008;border-color:#00000014}[data-theme=light] .today-hero__activity-icon-wrap{background:#1a1a1a}[data-theme=light] .day-row__header:hover{background:#00000008}[data-theme=light] .beach-search__item:hover,[data-theme=light] .beach-search__item:active{background:#0000000a}[data-theme=light] .lieux-fav-info:hover{background:#00000008}[data-theme=light] .fav-btn:hover{background:#0000000f}*,:before,:after{box-sizing:border-box}body{margin:0}#root{max-width:480px;min-height:100svh;margin:0 auto}h1,h2,h3{color:var(--text-heading);margin:0}p{margin:0}.app{flex-direction:column;min-height:100svh;padding-bottom:64px;display:flex}.app-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 16px 14px;display:flex}.app-title{letter-spacing:-.5px;color:var(--color-ok);margin:0;font-size:22px;font-weight:700}.app-settings-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0;font-size:24px;line-height:1;transition:background .15s,color .15s;display:flex}.app-settings-btn:hover{background:var(--bg-card);color:var(--text)}.app-main{flex:1}.app-status{color:var(--text-muted);text-align:center;padding:32px 16px;font-size:14px}.app-status--error{color:var(--color-no)}.beach-search{border-bottom:1px solid var(--border);padding:10px 16px}.beach-search--selected{justify-content:space-between;align-items:center;gap:12px;display:flex}.beach-search__inner{position:relative}.beach-search__input{box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:10px 12px;font-size:14px}.beach-search__input:focus{border-color:var(--color-ok)}.beach-search__input::placeholder{color:var(--text-muted)}.beach-search__dropdown{background:var(--bg-card);border:1px solid var(--border);z-index:100;border-radius:8px;max-height:280px;margin:0;padding:0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.beach-search__item{cursor:pointer;border-bottom:1px solid var(--border);flex-direction:column;padding:10px 14px;display:flex}.beach-search__item:last-child{border-bottom:none}.beach-search__item:hover,.beach-search__item:active{background:#ffffff0a}.beach-search__item-nom{color:var(--text);font-size:13px;font-weight:600}.beach-search__item-commune{color:var(--text-muted);margin-top:2px;font-size:11px}.beach-search__info{flex-direction:column;gap:2px;min-width:0;display:flex}.beach-search__nom-row{align-items:center;gap:4px;min-width:0;display:flex}.beach-search__nom{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.beach-search__fav{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-shrink:0;padding:0 1px;font-size:16px;line-height:1;transition:color .15s}.beach-search__fav--active,.beach-search__fav:hover{color:var(--color-brand-sun)}.beach-search__commune{color:var(--text-muted);font-size:12px}.beach-search__change{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;padding:5px 10px;font-size:12px;line-height:1.4}.beach-search__change:hover{background:var(--bg-card);color:var(--text)}.activity-chip{border-radius:12px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;line-height:1.4;display:inline-flex}.activity-chip[data-status=OK]{background:#1d9e7524}.activity-chip[data-status=WARN]{background:#ef9f2724}.activity-chip[data-status=NO]{background:#e24b4a24}.activity-chip__dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.activity-chip[data-status=OK] .activity-chip__dot{background:var(--color-ok)}.activity-chip[data-status=WARN] .activity-chip__dot{background:var(--color-warn)}.activity-chip[data-status=NO] .activity-chip__dot{background:var(--color-no)}.activity-chip__label{color:var(--text);font-weight:500}.activity-chip__status{color:var(--text-muted);font-size:10px}.metrics-grid{background:var(--bg);border-radius:8px;grid-template-columns:repeat(4,1fr);gap:4px;padding:10px 12px;display:grid}.metric{flex-direction:column;align-items:center;gap:2px;display:flex}.metric__emoji{font-size:14px;line-height:1.2}.metric__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:10px}.metric__value{color:var(--text);font-size:15px;font-weight:700}.day-row{border-bottom:1px solid var(--border)}.day-row__header{cursor:pointer;width:100%;color:inherit;text-align:left;background:0 0;border:none;flex-direction:column;gap:8px;padding:12px 16px 10px;display:flex}.day-row__header:hover{background:#ffffff05}.day-row__meta{align-items:center;gap:10px;display:flex}.day-row__date{flex-direction:column;min-width:52px;display:flex}.day-row__name{color:var(--text-heading);font-size:13px;font-weight:600}.day-row__datestr{color:var(--text-muted);font-size:11px}.day-row__icon{font-size:18px;line-height:1}.day-row__temp{color:var(--text);font-size:15px;font-weight:600}.day-row__chevron{color:var(--text-muted);margin-left:auto;font-size:9px}.day-row__chips{gap:6px;display:flex}.day-row__chips .activity-chip{flex:1;justify-content:center}.day-row__body{flex-direction:column;gap:10px;padding:4px 16px 16px;display:flex}.day-row__activities{flex-direction:column;gap:6px;display:flex}.activity-item{background:var(--bg-card);border-radius:8px;display:flex;overflow:hidden}.activity-item__bar{flex-shrink:0;width:4px}.activity-item[data-status=OK] .activity-item__bar{background:var(--color-ok)}.activity-item[data-status=WARN] .activity-item__bar{background:var(--color-warn)}.activity-item[data-status=NO] .activity-item__bar{background:var(--color-no)}.activity-item__content{flex:1;padding:10px 12px}.activity-item__row{align-items:center;gap:10px;display:flex}.activity-item__icon{flex-shrink:0}.activity-item__text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.activity-item__label{color:var(--text-heading);font-size:14px;font-weight:700}.activity-item__status{font-size:11px;font-weight:600}.activity-item[data-status=OK] .activity-item__status{color:var(--color-ok)}.activity-item[data-status=WARN] .activity-item__status{color:var(--color-warn)}.activity-item[data-status=NO] .activity-item__status{color:var(--color-no)}.activity-item__reason{color:var(--text-muted);font-size:12px}.water-quality{background:var(--bg-card);border-left:3px solid var(--border);border-radius:8px;flex-direction:column;gap:3px;padding:10px 12px;display:flex}.water-quality[data-score="4"],.water-quality[data-score="3"]{border-left-color:var(--color-ok)}.water-quality[data-score="2"]{border-left-color:var(--color-warn)}.water-quality[data-score="1"]{border-left-color:var(--color-no)}.water-quality__row{justify-content:space-between;align-items:center;display:flex}.water-quality__title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:11px}.water-quality__badge{color:var(--text-heading);font-size:13px;font-weight:600}.water-quality[data-score="4"] .water-quality__badge,.water-quality[data-score="3"] .water-quality__badge{color:var(--color-ok)}.water-quality[data-score="2"] .water-quality__badge{color:var(--color-warn)}.water-quality[data-score="1"] .water-quality__badge{color:var(--color-no)}.water-quality[data-score="0"] .water-quality__badge{color:var(--text-muted)}.water-quality__meta{color:var(--text-muted);font-size:11px}.water-quality__link{color:var(--text-muted);align-self:flex-start;margin-top:2px;font-size:11px;text-decoration:none}.water-quality__link:hover{color:var(--text-heading);text-decoration:underline}.settings-overlay{z-index:300;opacity:0;pointer-events:none;background:#0009;transition:opacity .3s ease-out;position:fixed;inset:0}.settings-overlay--visible{opacity:1;pointer-events:auto}.settings-sheet{background:var(--bg-card);z-index:301;width:100%;max-width:480px;max-height:85vh;padding:0 16px max(32px, env(safe-area-inset-bottom));border-radius:20px 20px 0 0;transition:transform .3s ease-out;position:fixed;bottom:0;left:50%;overflow-y:auto;transform:translate(-50%)translateY(100%)}.settings-sheet--open{transform:translate(-50%)translateY(0)}.settings-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:12px auto 0}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 0 12px;display:flex}.settings-header__title{font-size:17px;font-weight:700}.settings-close-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 8px;font-size:16px;line-height:1;transition:background .15s,color .15s}.settings-close-btn:hover{color:var(--text);background:#8080801a}.settings-section{margin-bottom:24px}.settings-section__label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:11px;font-weight:700;display:block}.settings-theme-row{justify-content:space-between;align-items:center;display:flex}.toggle-switch{background:var(--border);cursor:pointer;border:none;border-radius:14px;flex-shrink:0;width:48px;height:28px;padding:0;transition:background .25s;position:relative}.toggle-switch--on{background:var(--color-ok)}.toggle-switch__thumb{pointer-events:none;background:#fff;border-radius:50%;width:22px;height:22px;transition:transform .25s;position:absolute;top:3px;left:3px;box-shadow:0 1px 4px #0000004d}.toggle-switch--on .toggle-switch__thumb{transform:translate(20px)}.settings__row{cursor:pointer;flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.settings__row:last-child{margin-bottom:0}.settings__label-row{justify-content:space-between;align-items:center;display:flex}.settings__label{color:var(--text);font-size:13px}.settings__value{color:var(--color-ok);text-align:right;min-width:54px;font-size:13px;font-weight:600}.settings__slider{width:100%;accent-color:var(--color-ok);cursor:pointer}.tab-bar{background:var(--bg-card);border-top:1px solid var(--border);z-index:200;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.tab-bar__item{cursor:pointer;color:var(--text-muted);background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 0 12px;font-family:inherit;font-size:11px;line-height:1.2;transition:color .15s;display:flex}.tab-bar__item--active{color:var(--color-brand-primary)}.tab-bar__item:not(.tab-bar__item--active):hover{color:var(--text)}.fav-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;flex-shrink:0;padding:4px 6px;font-size:20px;line-height:1;transition:color .15s,background .15s}.fav-btn--active{color:var(--color-brand-sun)}.fav-btn:hover{color:var(--color-brand-sun);background:#ffffff0d}.lieux-view{flex-direction:column;gap:28px;padding:20px 16px 0;display:flex}.lieux-section__title{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin:0 0 12px;font-size:11px;font-weight:700}.lieux-empty{color:var(--text-muted);text-align:center;padding:20px 0;font-size:13px}.lieux-favorites{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.lieux-fav-item{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;align-items:center;display:flex;overflow:hidden}.lieux-fav-info{cursor:pointer;text-align:left;min-width:0;color:inherit;background:0 0;border:none;flex-direction:column;flex:1;gap:2px;padding:12px 14px;display:flex}.lieux-fav-info:hover{background:#ffffff08}.lieux-fav-nom{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.lieux-fav-commune{color:var(--text-muted);font-size:11px}.lieux-fav-item .fav-btn{padding:12px 14px;font-size:18px}.lieux-view .beach-search{border-bottom:none;padding:0}.today-hero{padding:0 16px 16px}.today-hero__encart{background:#ffffff0d;border:1px solid #ffffff12;border-radius:20px;padding:16px}.today-hero__date-label{letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);margin:0 0 8px;font-size:11px;font-weight:700}.today-hero__note{color:var(--color-brand-primary);text-align:center;margin-top:8px;margin-bottom:0;font-family:Caveat,cursive;font-size:18px;font-style:italic}.today-hero__activity-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:18px;display:grid}.today-hero__activity-card{box-sizing:border-box;border-radius:14px;flex-direction:column;justify-content:space-between;height:108px;padding:12px 14px;display:flex}.today-hero__activity-card-top{justify-content:space-between;align-items:flex-start;display:flex}.today-hero__activity-icon-wrap{border-radius:8px;flex-shrink:0;width:32px;height:32px;overflow:hidden}.today-hero__activity-icon-wrap img{object-fit:contain;width:32px;height:32px;display:block}.today-hero__activity-badge{letter-spacing:.5px;text-transform:uppercase;border-radius:20px;padding:3px 9px;font-size:10px;font-weight:800}.today-hero__activity-card-bottom{flex-direction:column;gap:3px;display:flex}.today-hero__activity-name{color:var(--text-heading);letter-spacing:-.2px;font-size:14px;font-weight:800}.today-hero__activity-reason{color:var(--text-muted);font-size:11px}.today-hero__metrics{background:var(--bg-card);border-radius:12px;grid-template-columns:repeat(4,1fr);margin-top:12px;padding:12px 8px;display:grid}.today-hero__metric{flex-direction:column;align-items:center;gap:2px;display:flex}.today-hero__metric-emoji{font-size:14px;line-height:1.2}.today-hero__metric-label{letter-spacing:.6px;color:var(--text-muted);text-transform:uppercase;font-size:9px;font-weight:700}.today-hero__metric-value{color:var(--text-heading);font-size:15px;font-weight:700;line-height:1.2}.today-hero__metric-unit{color:var(--text-muted);font-size:11px;font-weight:400}.today-hero__sun-times{justify-content:space-between;align-items:center;margin-top:12px;margin-bottom:8px;padding:0 8px;display:flex}.today-hero__sun-muted{color:var(--text-muted);letter-spacing:.3px;font-size:11px}.today-hero__sun-now{color:var(--color-brand-primary);letter-spacing:.3px;font-size:13px;font-weight:700}.daily-counsel{flex-direction:column;gap:12px;padding:4px 16px 8px;display:flex}.daily-counsel__section-title{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin:0 0 10px;font-size:11px;font-weight:700}.daily-counsel__card{background:#ffffff0f;border:1px solid #ffffff14;border-radius:14px;flex-direction:column;gap:12px;padding:14px 16px;display:flex}[data-theme=light] .daily-counsel__card{background:#00000008;border-color:#00000012}.daily-counsel__row{align-items:center;gap:12px;display:flex}.daily-counsel__icon{text-align:center;flex-shrink:0;width:26px;font-size:20px;line-height:1}.daily-counsel__texts{flex-direction:column;gap:2px;display:flex}.daily-counsel__label{color:var(--text-heading);font-size:13px;font-weight:600;line-height:1.3}.daily-counsel__sub{color:var(--text-muted);font-size:11px}.daily-counsel__divider{background:var(--border);height:1px}.caveat-citation{color:var(--color-brand-primary);text-align:center;margin:0;padding:0 8px;font-family:Caveat,cursive;font-style:italic;line-height:1.4}.caveat-text{font-size:clamp(20px,5vw,26px)}.caveat-author{opacity:.7;font-size:13px;font-style:normal}.prochains-jours{flex-direction:column;margin-top:8px;display:flex}.prochains-jours__title{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin:0;padding:12px 16px 8px;font-size:11px;font-weight:700}.prochains-jours .day-row{border:.5px solid var(--border);border-bottom:.5px solid var(--border);border-radius:12px;margin:0 16px 8px;overflow:hidden}.oualler-view{flex-direction:column;gap:0;padding:20px 16px 32px;display:flex}.oualler-view--empty{text-align:center;align-items:center;padding:56px 24px 32px}.oualler-view__title{color:var(--text-heading);letter-spacing:-.5px;margin:0 0 4px;font-size:28px;font-weight:800}.oualler-view__subtitle{color:var(--color-brand-primary);margin:0 0 20px;font-size:14px;font-weight:500}.oualler-view__message{color:var(--text-muted);max-width:260px;margin-top:16px;font-size:13px;line-height:1.6}.oualler-view__label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin:0 0 10px;font-size:11px;font-weight:700}.oualler-view__list,.oualler-view__skeletons{flex-direction:column;gap:10px;display:flex}.oualler-sk{border-left:4px solid var(--border);border-radius:14px;height:140px}.fav-card{background:var(--bg-card);border:.5px solid var(--border);cursor:pointer;text-align:left;color:inherit;box-sizing:border-box;border-radius:14px;flex-direction:column;gap:12px;width:100%;padding:14px;font-family:inherit;transition:background .15s;display:flex}.fav-card:hover{background:#ffffff0a}.fav-card__header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.fav-card__title-block{flex-direction:column;gap:2px;min-width:0;display:flex}.fav-card__nom{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:700;overflow:hidden}.fav-card__commune{color:var(--text-muted);font-size:12px}.fav-card__header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.fav-card__weather{align-items:center;gap:4px;display:flex}.fav-card__weather-icon{font-size:22px;line-height:1}.fav-card__weather-temp{color:var(--text-heading);font-size:20px;font-weight:700;line-height:1}.fav-card__star{color:var(--color-brand-sun);font-size:16px}.fav-card__grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.fav-card__activity{background:var(--bg);border-radius:10px;flex-direction:row;align-items:center;gap:8px;padding:9px 10px;display:flex}.fav-card__activity-icon{object-fit:contain;flex-shrink:0;display:block}.fav-card__activity-text{flex-direction:column;gap:2px;min-width:0;display:flex}.fav-card__activity-name{color:var(--text-heading);font-size:13px;font-weight:700;line-height:1.2}.fav-card__activity-status{font-size:12px;font-weight:600;line-height:1.2}.fav-card__loading{color:var(--text-muted);text-align:center;padding:16px 0 4px;font-size:13px}.mesplages-view{flex-direction:column;gap:0;display:flex}.mesplages-search{border-bottom:1px solid var(--border);align-items:center;padding:10px 16px;display:flex;position:relative}.mesplages-search__icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:28px}.mesplages-search__input{box-sizing:border-box;background:var(--bg-card);border:1px solid var(--border);width:100%;color:var(--text);appearance:none;border-radius:10px;outline:none;padding:10px 36px;font-family:inherit;font-size:14px}.mesplages-search__input::-webkit-search-cancel-button{display:none}.mesplages-search__input:focus{border-color:var(--color-brand-primary)}.mesplages-search__input::placeholder{color:var(--text-muted)}.mesplages-search__clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;padding:4px 6px;font-size:12px;line-height:1;transition:color .15s;position:absolute;right:24px}.mesplages-search__clear:hover{color:var(--text)}.mesplages-section{padding:16px 16px 4px}.mesplages-section__title{letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin:0 0 10px;font-size:11px;font-weight:700}.mesplages-empty{color:var(--text-muted);text-align:center;margin:0;padding:16px 0 20px;font-size:13px}.mesplages-list{flex-direction:column;margin:0 0 12px;padding:0;list-style:none;display:flex}.mesplages-row{border-bottom:1px solid var(--border);align-items:center;display:flex}.mesplages-row:last-child{border-bottom:none}.mesplages-row__info{cursor:pointer;text-align:left;color:inherit;background:0 0;border:none;flex:1;align-items:center;gap:12px;min-width:0;padding:12px 8px 12px 0;font-family:inherit;display:flex}.mesplages-row__info:hover{background:0 0}.mesplages-row__dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.mesplages-row__text{flex-direction:column;gap:2px;min-width:0;display:flex}.mesplages-row__nom{color:var(--text-heading);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.mesplages-row__sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.mesplages-row .fav-btn{padding:10px 12px;font-size:18px}@keyframes sk-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sk{background:linear-gradient(90deg, var(--skeleton-base) 25%, var(--skeleton-shine) 50%, var(--skeleton-base) 75%);background-size:200% 100%;animation:1.6s ease-in-out infinite sk-shimmer}.skeleton-hero{padding:0 16px 16px}.skeleton-hero__encart{background:#ffffff0d;border:1px solid #ffffff12;border-radius:20px;padding:16px}[data-theme=light] .skeleton-hero__encart{background:#00000008;border-color:#00000014}.skeleton-hero__note-wrap{justify-content:center;margin-top:8px;display:flex}.skeleton-activity-grid{grid-template-columns:1fr 1fr;gap:10px;margin-top:18px;display:grid}.skeleton-metrics{background:var(--bg-card);border-radius:12px;grid-template-columns:repeat(4,1fr);margin-top:12px;padding:12px 8px;display:grid}.skeleton-metric-col{flex-direction:column;align-items:center;gap:4px;display:flex}
