:root{--bg: #f6f8fa;--text: #0f172a;--accent: #0ea5a4}body.theme-default{background:var(--bg);color:var(--text)}body.theme-clear{background:linear-gradient(180deg,#a7d8ff,#f0fbff);color:#052d4a}body.theme-cloudy{background:linear-gradient(180deg,#d7dae0,#f3f4f6);color:#07122a}body.theme-rain{background:linear-gradient(180deg,#9fb7c8,#e6f0f6);color:#05222f}body.theme-snow{background:linear-gradient(180deg,#fff,#eaf6ff);color:#06324a}body.theme-fog{background:linear-gradient(180deg,#e9edf0,#fbfbfd);color:#24313a}body.theme-cold{background:linear-gradient(180deg,#dbeafe,#eef2ff);color:#06203a}body.theme-warm{background:linear-gradient(180deg,#fff4e6,#fffaf0);color:#3b2f1b}.app-root{max-width:900px;margin:24px auto;padding:18px;font-family:Inter,Roboto,system-ui,-apple-system}.app-header h1{margin:0 0 6px;font-size:1.6rem}.subtitle{margin:0;color:#0009;font-size:.9rem}.controls{margin-top:14px}.current{margin-top:18px}.current-card{display:flex;justify-content:space-between;align-items:center;padding:12px;border-radius:8px;background:#fff9;box-shadow:0 2px 8px #0206170f}.current-main{display:flex;flex-direction:column}.current-desc{font-size:1.1rem;font-weight:600}.current-temp{font-size:1.8rem;font-weight:700}.current-meta{text-align:right;min-width:140px}.forecast{margin-top:18px}.loading{color:#0009}.error{color:#b30000}app-forecast{display:block}.wind-row{display:flex;align-items:center;gap:8px;justify-content:flex-end}.wind-icon{width:20px;height:20px;display:inline-block;transform-origin:center 10px;transition:transform .2s ease}.wind-text{font-size:.95rem}.wind-label{color:#0009;margin-right:6px}.section-title{font-size:1.2rem;font-weight:700;margin:0 0 10px}.buoy-section{margin-top:22px}.buoy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.buoy-card{padding:12px;border-radius:8px;background:#fff9;box-shadow:0 2px 8px #0206170f}.buoy-header{display:flex;align-items:baseline;gap:8px;margin-bottom:8px;flex-wrap:wrap}.buoy-id{font-weight:700;font-size:1rem;color:var(--accent)}.buoy-name{font-size:.85rem;color:#000000b3}.buoy-type{font-size:.75rem;color:#00000073;text-transform:uppercase;letter-spacing:.04em}.buoy-obs{display:flex;flex-direction:column;gap:4px}.buoy-stat{display:flex;justify-content:space-between;align-items:baseline;font-size:.9rem}.buoy-label{color:#0009}.buoy-value{font-weight:600;text-align:right}.buoy-sub{font-weight:400;color:#00000080;font-size:.82rem}.buoy-empty{color:#00000073;font-style:italic;font-size:.88rem}.skeleton{position:relative;overflow:hidden;background:#eef3f6;border-radius:6px}.skeleton:after{content:"";position:absolute;top:0;left:-150px;height:100%;width:150px;background:linear-gradient(90deg,#fff0,#fff9,#fff0);animation:shimmer 1.2s infinite}@keyframes shimmer{to{left:100%}}.buoy-skeleton-line{height:12px;margin:6px 0;border-radius:6px;background:linear-gradient(90deg,#e9eef2,#e3e9ee)}.buoy-skeleton-header{display:flex;gap:8px;align-items:center;margin-bottom:8px}.buoy-skeleton-header .line{width:40%;height:14px}.buoy-skeleton-sub{width:60%;height:10px}.error.help{background:#fff4f4;padding:8px;border-radius:6px;border:1px solid #f0c6c6;color:#7a1515}
