html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg: #FCFAF5;--color-bg-secondary: #f0f5f5;--color-surface: #ffffff;--color-surface-glass: rgba(255, 255, 255, .75);--color-text: #222222;--color-text-muted: #666666;--color-text-light: #999999;--color-accent: rgba(35, 80, 85, 1);--color-accent-hover: rgba(28, 64, 68, 1);--color-accent-light: rgba(35, 80, 85, .1);--color-accent-border: rgba(35, 80, 85, .25);--color-border: rgba(0, 0, 0, .1);--color-nav-bg: #FCFAF5;--color-input-bg: #ffffff;--color-card-bg: rgba(249, 253, 249, .85);--color-section-bg: rgba(255, 255, 255, .75);--color-error-bg: #fdecea;--color-error-border: #f44336;--color-error-text: #c62828;--color-success-bg: #e8f5e9;--color-success-border: #4caf50;--color-success-text: #2e7d32;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 20px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .18);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--transition-fast: .15s ease;--transition-base: .25s ease}[data-theme=dark]{--color-bg: #0d1c1e;--color-bg-secondary: #132022;--color-surface: #1c2f32;--color-surface-glass: rgba(28, 47, 50, .85);--color-text: #e4f0f1;--color-text-muted: #8fb5b9;--color-text-light: #5e8a8e;--color-accent: rgba(90, 175, 185, 1);--color-accent-hover: rgba(110, 195, 205, 1);--color-accent-light: rgba(90, 175, 185, .12);--color-accent-border: rgba(90, 175, 185, .3);--color-border: rgba(90, 175, 185, .15);--color-nav-bg: #0d1c1e;--color-input-bg: #1c2f32;--color-card-bg: rgba(28, 47, 50, .9);--color-section-bg: rgba(28, 47, 50, .85);--color-error-bg: rgba(198, 40, 40, .15);--color-error-border: rgba(244, 67, 54, .5);--color-error-text: #ff8a80;--color-success-bg: rgba(46, 125, 50, .15);--color-success-border: rgba(76, 175, 80, .5);--color-success-text: #69f0ae;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .4);--shadow-md: 0 4px 20px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6)}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:var(--color-bg);color:var(--color-text);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}h1,h2,h3,h4,h5,h6,p{margin:0;padding:0}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;justify-content:center;align-items:center;z-index:2000;padding:16px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal-content{background:var(--color-surface);padding:36px 32px 32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:520px;width:100%;position:relative;max-height:90vh;overflow-y:auto;border:1px solid var(--color-border)}.modal-close{position:absolute;top:14px;right:14px;background:var(--color-accent-light);border:none;color:var(--color-accent);cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast),transform var(--transition-fast)}.modal-close:hover{background:var(--color-accent-border);transform:rotate(90deg)}.navigation{background:var(--color-nav-bg);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:1000;transition:background-color .3s ease}.navigation__container{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center;min-height:72px}.navigation__logo-link{display:flex;align-items:center;transition:opacity var(--transition-fast);flex-shrink:0}.navigation__logo-link:hover{opacity:.85}.navigation__logo-wrap{position:relative;display:inline-flex;flex-direction:column;align-items:flex-end}.navigation__logo-image{height:68px;width:auto;display:block}.navigation__logo-indigenous{position:absolute;bottom:4px;right:0;width:63%;text-align:center;font-size:16.5px;font-family:Cinzel,serif;color:#235055;letter-spacing:.03em;pointer-events:none;line-height:1}.navigation__menu--desktop{display:flex;list-style:none;margin:0;padding:0;gap:4px}.navigation__link{color:var(--color-text-muted);text-decoration:none;font-size:15px;font-weight:600;padding:8px 14px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast),color var(--transition-fast);display:block;font-family:Cinzel,serif;position:relative}.navigation__link:hover{color:var(--color-accent);background-color:var(--color-accent-light)}.navigation__link--active{color:var(--color-accent)}.navigation__link--active:after{content:"";position:absolute;bottom:2px;left:14px;right:14px;height:2px;background:var(--color-accent);border-radius:2px}.navigation__actions{display:flex;align-items:center;gap:12px}.navigation__theme-toggle{background:var(--color-accent-light);border:1.5px solid var(--color-accent-border);color:var(--color-accent);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);flex-shrink:0}.navigation__theme-toggle:hover{background:var(--color-accent-border);transform:rotate(20deg)}.navigation__auth--desktop{display:flex;gap:8px;align-items:center}.navigation__auth-button{background:var(--color-accent);color:#fff;border:1.5px solid var(--color-accent);padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);font-family:Cinzel,serif;white-space:nowrap}.navigation__auth-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm);background:var(--color-accent-hover)}.navigation__auth-button--outline{background:transparent;color:var(--color-accent)}.navigation__auth-button--outline:hover{background:var(--color-accent-light)}.navigation__auth-button--full{width:100%}.navigation__hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.navigation__hamburger:hover{background:var(--color-accent-light)}.navigation__hamburger span{display:block;width:22px;height:2px;background:var(--color-accent);border-radius:2px;transition:transform .3s ease,opacity .3s ease,width .3s ease;transform-origin:center}.navigation__hamburger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.navigation__hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.navigation__hamburger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.navigation__backdrop{position:fixed;inset:0;background:#0006;z-index:1001;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.navigation__drawer{position:fixed;top:0;right:0;bottom:0;width:min(300px,85vw);background:var(--color-nav-bg);z-index:1002;padding:80px 24px 32px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow-y:auto}.navigation__drawer-menu{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;flex:1}.navigation__drawer-link{display:block;padding:14px 16px;font-family:Cinzel,serif;font-size:16px;font-weight:600;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast)}.navigation__drawer-link:hover,.navigation__drawer-link--active{color:var(--color-accent);background:var(--color-accent-light)}.navigation__drawer-auth{display:flex;flex-direction:column;gap:8px;margin-top:24px;padding-top:24px;border-top:1px solid var(--color-border)}.modal__title{color:var(--color-accent);font-size:28px;margin:0 0 24px;font-family:Cinzel,serif;font-weight:600;text-align:center}.auth-form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-form__group{margin-bottom:20px}.auth-form__label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.auth-form__input{width:100%;padding:11px 14px;border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);font-size:15px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit;box-sizing:border-box;background:var(--color-input-bg);color:var(--color-text)}.auth-form__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.auth-form__submit{width:100%;padding:14px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);margin-top:4px;display:flex;align-items:center;justify-content:center;min-height:48px}.auth-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm);background:var(--color-accent-hover)}.auth-form__submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-form__submit--logout{margin-top:24px;background:#c62828}.auth-form__submit--logout:hover:not(:disabled){background:#b71c1c}.auth-form__error{color:var(--color-error-text);font-size:13px;margin:-8px 0 12px;text-align:center;background:var(--color-error-bg);border:1px solid var(--color-error-border);padding:8px 12px;border-radius:var(--radius-sm)}.auth-form__forgot{display:block;margin-top:10px;background:none;border:none;color:var(--color-text-muted);font-size:13px;cursor:pointer;padding:0;font-family:inherit;text-decoration:underline;width:100%;text-align:center;transition:color var(--transition-fast)}.auth-form__forgot:hover{color:var(--color-accent)}.auth-form__success{color:var(--color-success-text);font-size:14px;text-align:center;background:var(--color-success-bg);border-radius:var(--radius-sm);padding:12px}.account-info{padding:8px 0}.account-info__item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-border);gap:16px}.account-info__item:last-of-type{border-bottom:none}.account-info__label{font-weight:600;color:var(--color-text-muted);font-size:13px;text-transform:uppercase;letter-spacing:.04em}.account-info__value{color:var(--color-text);font-size:15px}.btn-spinner{display:inline-block;width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.navigation__menu--desktop,.navigation__auth--desktop{display:none}.navigation__hamburger{display:flex}}@media(max-width:480px){.navigation__container{padding:0 16px}.navigation__logo-image{height:56px}.navigation__logo-indigenous{font-size:9px}}.tide-info{background:var(--color-accent-light);border:1.5px solid var(--color-accent-border);border-radius:var(--radius-md);padding:18px;margin-bottom:20px}.tide-info__tabs{display:flex;gap:8px;margin-bottom:14px}.tide-info__tab{padding:5px 16px;border-radius:20px;border:1.5px solid var(--color-accent-border);background:transparent;color:var(--color-text-muted);font-size:13px;cursor:pointer;font-family:inherit;transition:background var(--transition-fast),color var(--transition-fast)}.tide-info__tab:hover{background:var(--color-accent-light);color:var(--color-accent)}.tide-info__tab--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.tide-info__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}.tide-info__label{font-size:13px;color:var(--color-text-muted);font-weight:500}.tide-info__current-value{font-size:20px;font-weight:700;color:var(--color-accent);font-family:Cinzel,serif}.tide-info__date-picker{display:flex;align-items:center;gap:12px;margin-bottom:12px}.tide-info__date-input{border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);padding:5px 10px;font-size:13px;color:var(--color-text);background:var(--color-input-bg);font-family:inherit;cursor:pointer;transition:border-color var(--transition-fast)}.tide-info__date-input:focus{outline:none;border-color:var(--color-accent)}.tide-info__loading,.tide-info__error{color:var(--color-text-muted);font-size:14px;margin:0;text-align:center;padding:12px 0}.tide-info__error{color:var(--color-error-text)}.weather-info{background:var(--color-surface);border:1.5px solid var(--color-accent-border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.weather-info--loading,.weather-info--error{display:flex;flex-direction:column;gap:12px}.weather-info--error p{text-align:center;color:var(--color-text-muted);font-size:14px;padding:16px 0}.weather-info__topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.weather-info__location-label{font-size:13px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.weather-unit-toggle{display:flex;background:var(--color-bg-secondary);border-radius:20px;padding:2px;border:1.5px solid var(--color-accent-border)}.weather-unit-btn{padding:4px 12px;border-radius:18px;border:none;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.weather-unit-btn--active{background:var(--color-accent);color:#fff}.weather-info__hint{text-align:center;font-size:11px;color:var(--color-text-light);margin-top:8px}.weather-current{display:flex;align-items:center;gap:16px;padding-bottom:18px;margin-bottom:18px;border-bottom:1.5px solid var(--color-accent-border)}.weather-current__icon{flex-shrink:0}.weather-current__main{flex:1}.weather-current__temp{font-size:48px;font-weight:700;color:var(--color-text);line-height:1;font-family:Cinzel,serif}.weather-current__condition{font-size:16px;color:var(--color-accent);font-weight:600;margin-top:4px}.weather-current__location{font-size:13px;color:var(--color-text-muted);margin-top:2px}.weather-current__details{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.weather-detail{display:flex;flex-direction:column;align-items:flex-end}.weather-detail__label{font-size:11px;color:var(--color-text-light);text-transform:uppercase;letter-spacing:.04em}.weather-detail__value{font-size:14px;font-weight:600;color:var(--color-text)}.weather-forecast{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.forecast-day{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 4px;border-radius:var(--radius-sm);transition:background var(--transition-fast),transform var(--transition-fast);cursor:pointer;border:none;background:transparent;width:100%}.forecast-day:hover{background:var(--color-accent-light);transform:translateY(-2px)}.forecast-day__name{font-size:12px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.forecast-day__precip{font-size:11px;color:#42a5f5;font-weight:500;min-height:14px}.forecast-day__temps{display:flex;gap:4px;align-items:baseline}.forecast-day__high{font-size:15px;font-weight:700;color:var(--color-text)}.forecast-day__low{font-size:12px;color:var(--color-text-muted)}.weather-icon{display:flex;align-items:center;justify-content:center}.weather-icon--lg .weather-svg{width:72px;height:72px}.weather-icon--md .weather-svg{width:48px;height:48px}.weather-icon--sm .weather-svg{width:36px;height:36px}.weather-icon--xs .weather-svg{width:28px;height:28px}.weather-svg__ray{transform-origin:32px 32px;animation:ray-pulse 2s ease-in-out infinite}@keyframes ray-pulse{0%,to{opacity:1}50%{opacity:.5}}.weather-svg__moon{animation:moon-glow 3s ease-in-out infinite}@keyframes moon-glow{0%,to{opacity:1}50%{opacity:.8}}.weather-svg__star{animation:twinkle 2s ease-in-out infinite}@keyframes twinkle{0%,to{opacity:1;r:1.5px}50%{opacity:.3;r:.8px}}.weather-svg__drop{animation:fall 1.2s linear infinite}@keyframes fall{0%{transform:translateY(-4px);opacity:0}30%{opacity:1}to{transform:translateY(10px);opacity:0}}.weather-svg__snowflake{animation:drift 2s ease-in-out infinite}@keyframes drift{0%,to{transform:translateY(0) rotate(0);opacity:1}50%{transform:translateY(4px) rotate(20deg);opacity:.7}}.weather-svg__fog-line{animation:fog-drift 3s ease-in-out infinite}@keyframes fog-drift{0%,to{transform:translate(0);opacity:.7}50%{transform:translate(4px);opacity:.4}}.weather-svg__bolt{animation:flash 3s ease-in-out infinite}@keyframes flash{0%,85%,to{opacity:1;filter:drop-shadow(0 0 4px #FFD600)}90%{opacity:.1}95%{opacity:1}}.weather-svg__sun-core{animation:sun-pulse 2.5s ease-in-out infinite;transform-origin:32px 32px}@keyframes sun-pulse{0%,to{r:13}50%{r:14.5}}.hourly-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:16px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.hourly-modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.hourly-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1.5px solid var(--color-accent-border);flex-shrink:0}.hourly-modal__title{font-family:Cinzel,serif;font-size:18px;font-weight:600;color:var(--color-accent);margin:0}.hourly-modal__close{background:var(--color-accent-light);border:none;color:var(--color-accent);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);flex-shrink:0}.hourly-modal__close:hover{background:var(--color-accent-border);transform:rotate(90deg)}.hourly-modal__list{overflow-y:auto;padding:8px 0}.hourly-row{display:grid;grid-template-columns:56px 32px 1fr auto auto;align-items:center;gap:10px;padding:10px 24px;border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.hourly-row:last-child{border-bottom:none}.hourly-row:hover{background:var(--color-accent-light)}.hourly-row__time{font-size:13px;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.hourly-row__condition{font-size:13px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hourly-row__temp{font-size:15px;font-weight:700;color:var(--color-text);text-align:right;white-space:nowrap}.hourly-row__details{display:flex;flex-direction:column;align-items:flex-end;gap:2px;min-width:72px}.hourly-row__precip,.hourly-row__wind{font-size:11px;color:var(--color-text-muted);white-space:nowrap}.hourly-row__precip{color:#42a5f5}.weather-skeleton{background:linear-gradient(90deg,var(--color-accent-border) 25%,var(--color-accent-light) 50%,var(--color-accent-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.weather-skeleton--current{height:96px;border-radius:var(--radius-md)}.weather-skeleton__forecast{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.weather-skeleton--day{height:80px;border-radius:var(--radius-sm)}@media(max-width:500px){.weather-current{flex-wrap:wrap;gap:12px}.weather-current__details{flex-direction:row;align-items:flex-start;gap:16px;width:100%;border-top:1px solid var(--color-border);padding-top:10px}.weather-detail{align-items:flex-start}.weather-current__temp{font-size:40px}.forecast-day__name{font-size:10px}}.welcome{min-height:100vh;background:var(--color-bg)}.welcome__hero{position:relative;height:480px;overflow:hidden}.welcome__hero-image{width:100%;height:100%;object-fit:cover;object-position:center 40%;display:block}.welcome__hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#00000026,#0000008c);display:flex;align-items:flex-end;padding:48px}.welcome__hero-text{color:#fff}.welcome__hero-title{font-size:62px;font-weight:700;font-family:Cinzel,serif;text-shadow:0 2px 12px rgba(0,0,0,.5);line-height:1.1;margin-bottom:10px}.welcome__hero-subtitle{font-size:22px;font-family:Cinzel,serif;text-shadow:0 2px 8px rgba(0,0,0,.5);opacity:.92}.welcome__unit-row{display:flex;justify-content:flex-end;margin-bottom:14px}.welcome__unit-toggle{display:flex;background:var(--color-surface);border-radius:20px;padding:3px;border:1.5px solid var(--color-accent-border);box-shadow:var(--shadow-sm)}.welcome__unit-btn{padding:6px 16px;border-radius:18px;border:none;background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.welcome__unit-btn:hover{color:var(--color-accent)}.welcome__unit-btn--active{background:var(--color-accent);color:#fff}.welcome__body{background:linear-gradient(to bottom,rgba(35,80,85,.12) 0%,var(--color-bg) 120px);padding:40px 16px 48px}.welcome__container{max-width:860px;margin:0 auto}@media(max-width:900px){.welcome__hero{height:320px}.welcome__hero-overlay{padding:32px 24px}.welcome__hero-title{font-size:40px}.welcome__hero-subtitle{font-size:17px}}@media(max-width:600px){.welcome__hero{height:220px}.welcome__hero-title{font-size:30px;margin-bottom:6px}.welcome__hero-subtitle{font-size:14px}.welcome__hero-overlay,.welcome__section{padding:20px}.welcome__section-title{font-size:18px}}.skeleton{background:linear-gradient(90deg,var(--color-accent-border) 25%,var(--color-accent-light) 50%,var(--color-accent-border) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{border:2px solid var(--color-accent-border);border-radius:var(--radius-md);padding:16px;background:var(--color-card-bg)}.skeleton-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--color-accent-border)}.skeleton--title{height:20px;width:140px}.skeleton--badge{height:24px;width:80px;border-radius:20px}.skeleton--line{height:14px;width:100%;margin-bottom:8px}.skeleton--line-short{width:60%}.skeleton--slot{height:68px;border-radius:var(--radius-sm)}.sightings{min-height:100vh;background-image:url(/assets/water-ripple-CHO0TS-b.jpeg);background-size:cover;background-position:top;background-attachment:scroll;padding:32px 16px}.sightings__container{max-width:1200px;margin:0 auto}.sightings__header{background:transparent;color:#fff;padding:48px 32px;text-align:center}.sightings__title{margin:0 0 8px;font-size:56px;font-weight:700;text-shadow:2px 2px 8px rgba(0,0,0,.7);font-family:Cinzel,serif}.sightings__subtitle{margin:0;font-size:29px;text-shadow:2px 2px 6px rgba(0,0,0,.7);font-family:Cinzel,serif}.sightings__content{margin-top:32px;max-width:800px;margin-left:auto;margin-right:auto}.sightings__report-button{width:100%;padding:19px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:21px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);margin-bottom:24px;font-family:Cinzel,serif;letter-spacing:.02em}.sightings__report-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d;background:var(--color-accent-hover)}.sightings__report-button:active{transform:translateY(0)}.sightings__list-section{background:var(--color-section-bg);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sightings__section-title{color:var(--color-accent);font-size:28px;margin:0 0 24px;border-bottom:2px solid var(--color-accent-border);padding-bottom:10px;font-family:Cinzel,serif;font-weight:500}.sightings__empty-state{text-align:center;padding:40px 24px}.sightings__empty-icon{font-size:52px;display:block;margin-bottom:12px;animation:bob 3s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.sightings__empty-title{font-size:18px;font-weight:600;color:var(--color-text);margin-bottom:4px}.sightings__empty-text{color:var(--color-text-muted);font-size:14px}.sightings__list{display:flex;flex-direction:column;gap:14px;max-height:600px;overflow-y:auto}.sighting-card{border:1.5px solid var(--color-accent-border);border-radius:var(--radius-md);padding:18px;background:var(--color-card-bg);cursor:default;transition:border-color var(--transition-base)}.sighting-card:hover{border-color:var(--color-accent)}.sighting-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--color-accent-border)}.sighting-card__species{margin:0;color:var(--color-accent);font-size:17px;font-weight:600}.sighting-card__count{background:var(--color-accent);color:#fff;padding:3px 12px;border-radius:20px;font-size:13px;font-weight:500}.sighting-card__details{color:var(--color-text)}.sighting-card__detail{margin:6px 0;font-size:14px;color:var(--color-text-muted)}.sighting-card__detail strong{color:var(--color-text)}.sighting-card__notes{margin-top:10px;padding:10px 12px;background:var(--color-accent-light);border-radius:var(--radius-sm);font-size:13px;color:var(--color-text-muted);border-left:3px solid var(--color-accent)}.sightings-form__group{margin-bottom:20px}.sightings-form__label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.sightings-form__input{width:100%;padding:11px 14px;border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);font-size:15px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit;background:var(--color-input-bg);color:var(--color-text)}.sightings-form__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.sightings-form__input--select{cursor:pointer}.sightings-form__input--textarea{resize:vertical;min-height:80px}.sightings-form__submit{width:100%;padding:14px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);display:flex;align-items:center;justify-content:center;min-height:48px}.sightings-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm);background:var(--color-accent-hover)}.sightings-form__submit:disabled{opacity:.6;cursor:not-allowed}.sightings-form__message{padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:12px}.sightings-form__message--error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error-text)}@media(max-width:900px){.sightings{background-image:none;background-color:var(--color-bg-secondary)}.sightings__header{color:var(--color-accent)}.sightings__title,.sightings__subtitle{text-shadow:none}}@media(max-width:768px){.sightings__title{font-size:36px}.sightings__subtitle{font-size:18px}.sightings__header{padding:32px 16px}.sightings__list-section{padding:20px}.sightings__report-button{font-size:17px;padding:16px}}.courts{min-height:100vh;background-image:url(/assets/courts-background-B9iBexp3.jpeg);background-size:cover;background-position:center;background-repeat:no-repeat;padding:32px 16px}.courts__container{max-width:1200px;margin:0 auto}.courts__header{color:#fff;padding:48px 32px;text-align:center}.courts__title{margin:0 0 8px;font-size:56px;font-weight:700;font-family:Cinzel,serif;text-shadow:2px 2px 8px rgba(0,0,0,.7)}.courts__subtitle{margin:0;font-size:29px;opacity:.95;font-family:Cinzel,serif;text-shadow:2px 2px 6px rgba(0,0,0,.7)}.courts__content{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:32px}.courts__form-section,.courts__schedule-section{background:var(--color-section-bg);padding:32px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.courts__section-title{color:var(--color-accent);font-size:22px;margin:0 0 24px;border-bottom:2px solid var(--color-accent-border);padding-bottom:10px;font-family:Cinzel,serif;font-weight:500}.courts-form__group{margin-bottom:20px}.courts-form__label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.courts-form__input{width:100%;padding:11px 14px;border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);font-size:15px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit;background:var(--color-input-bg);color:var(--color-text)}.courts-form__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.courts-form__input--select{cursor:pointer}.courts-form__submit{width:100%;padding:14px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);display:flex;align-items:center;justify-content:center;min-height:48px}.courts-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm);background:var(--color-accent-hover)}.courts-form__submit:disabled{opacity:.6;cursor:not-allowed}.courts__date-picker{margin-bottom:24px}.courts__date-label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.courts__date-input{width:100%;padding:11px 14px;border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);font-size:15px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background:var(--color-input-bg);color:var(--color-text)}.courts__date-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.courts__empty-state{text-align:center;padding:32px 16px}.courts__empty-icon{font-size:44px;display:block;margin-bottom:12px}.courts__empty-title{font-size:16px;font-weight:600;color:var(--color-text);margin-bottom:4px}.courts__empty-text{color:var(--color-text-muted);font-size:14px}.courts__schedules{display:flex;flex-direction:column;gap:20px}.court-schedule{border:1.5px solid var(--color-accent-border);border-radius:var(--radius-md);padding:16px;background:var(--color-card-bg)}.court-schedule__title{margin:0 0 14px;font-size:17px;font-weight:600;padding-bottom:10px;border-bottom:1.5px solid var(--color-accent-border)}.court-schedule__title--pickleball{color:#7b1fa2}.court-schedule__title--tennis{color:#0277bd}[data-theme=dark] .court-schedule__title--pickleball{color:#ce93d8}[data-theme=dark] .court-schedule__title--tennis{color:#81d4fa}.court-schedule__slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.time-slot{padding:11px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:3px;cursor:default}.time-slot--available{background:var(--color-success-bg);border:1.5px solid var(--color-success-border)}.time-slot--booked{background:var(--color-error-bg);border:1.5px solid var(--color-error-border)}.time-slot__time{font-weight:600;color:var(--color-text);font-size:14px}.time-slot__status{font-size:12px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-slot--available .time-slot__status{color:var(--color-success-text);font-weight:500}.time-slot--booked .time-slot__status{color:var(--color-error-text);font-weight:500}.courts-form__message{padding:10px 14px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:12px}.courts-form__message--error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error-text)}@media(max-width:900px){.courts{background-image:none;background-color:var(--color-bg-secondary)}.courts__header{color:var(--color-accent)}.courts__title,.courts__subtitle{text-shadow:none}}@media(max-width:968px){.courts__content{grid-template-columns:1fr}.court-schedule__slots{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(max-width:768px){.courts__title{font-size:32px}.courts__subtitle{font-size:16px}.courts__header{padding:32px 16px}.courts__form-section,.courts__schedule-section{padding:20px}.court-schedule__slots{grid-template-columns:1fr 1fr}}.footer{background:var(--color-nav-bg);border-top:1px solid var(--color-border);padding:32px 24px;transition:background-color .3s ease}.footer__container{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.footer__brand{display:flex;flex-direction:column;gap:4px}.footer__name{font-family:Cinzel,serif;font-size:16px;font-weight:700;color:var(--color-accent)}.footer__tagline{font-size:13px;color:var(--color-text-muted)}.footer__links{display:flex;gap:20px;flex-wrap:wrap}.footer__link{font-size:13px;color:var(--color-text-muted);font-family:Cinzel,serif;transition:color var(--transition-fast)}.footer__link:hover{color:var(--color-accent)}.footer__credit{font-size:12px;color:var(--color-text-light)}@media(max-width:600px){.footer__container{flex-direction:column;align-items:center;text-align:center;gap:16px}.footer__links{justify-content:center}}.not-found{min-height:70vh;display:flex;align-items:center;justify-content:center;padding:32px 16px;background:var(--color-bg)}.not-found__content{text-align:center;max-width:420px}.not-found__icon{font-size:72px;margin-bottom:16px;display:block;animation:bob 3s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.not-found__title{font-size:96px;font-weight:800;font-family:Cinzel,serif;color:var(--color-accent);line-height:1;margin-bottom:8px}.not-found__subtitle{font-size:24px;font-family:Cinzel,serif;color:var(--color-text);margin-bottom:16px}.not-found__message{color:var(--color-text-muted);margin-bottom:32px;font-size:16px;line-height:1.6}.not-found__button{display:inline-block;padding:14px 32px;background:var(--color-accent);color:#fff;border-radius:var(--radius-md);font-size:16px;font-weight:600;font-family:Cinzel,serif;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.not-found__button:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.history{min-height:100vh;background-image:url(/assets/history-background-B0cUxPWe.JPG);background-size:cover;background-position:center 30%;background-attachment:scroll;padding:32px 16px}.history__container{max-width:860px;margin:0 auto}.history__header{color:#fff;padding:48px 32px;text-align:center}.history__title{margin:0 0 8px;font-size:56px;font-weight:700;font-family:Cinzel,serif;text-shadow:2px 2px 8px rgba(0,0,0,.7)}.history__subtitle{margin:0;font-size:22px;font-family:Cinzel,serif;text-shadow:2px 2px 6px rgba(0,0,0,.7);opacity:.92}.history__sections{display:flex;flex-direction:column;gap:16px;margin-top:8px}.history__section{padding:28px 32px;background:var(--color-section-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border);transition:box-shadow var(--transition-base),transform var(--transition-base)}.history__section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.history__section-title{color:var(--color-accent);font-size:22px;margin-bottom:14px;font-family:Cinzel,serif;font-weight:500;padding-bottom:10px;border-bottom:1.5px solid var(--color-accent-border)}.history__section-text{line-height:1.7;color:var(--color-text-muted);font-size:15.5px}@media(max-width:900px){.history{background-image:none;background-color:var(--color-bg-secondary)}.history__header{color:var(--color-accent)}.history__title,.history__subtitle{text-shadow:none}}@media(max-width:768px){.history__title{font-size:36px}.history__subtitle{font-size:16px}.history__header{padding:32px 16px}.history__section{padding:20px}.history__section-title{font-size:18px}}.reset-password{min-height:70vh;background:var(--color-bg);display:flex;align-items:center;justify-content:center;padding:32px 16px}.reset-password__box{background:var(--color-surface);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.reset-password__title{color:var(--color-accent);font-family:Cinzel,serif;font-size:24px;font-weight:500;margin:0 0 24px;text-align:center}.reset-password__group{margin-bottom:20px}.reset-password__label{display:block;margin-bottom:6px;color:var(--color-text-muted);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.reset-password__input{width:100%;padding:11px 14px;border:1.5px solid var(--color-accent-border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box;background:var(--color-input-bg);color:var(--color-text)}.reset-password__input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-light)}.reset-password__submit{width:100%;padding:14px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;font-family:inherit;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.reset-password__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-sm);background:var(--color-accent-hover)}.reset-password__submit:disabled{opacity:.6;cursor:not-allowed}.reset-password__error{color:var(--color-error-text);font-size:13px;margin:-8px 0 16px;text-align:center;background:var(--color-error-bg);border:1px solid var(--color-error-border);padding:8px 12px;border-radius:var(--radius-sm)}.reset-password__success{color:var(--color-success-text);font-size:14px;text-align:center;padding:12px;background:var(--color-success-bg);border-radius:var(--radius-sm)}.app{min-height:100vh;display:flex;flex-direction:column}.app__main{flex:1}
