:root{--navy: #1e3a5f;--navy-dark: #152d4a;--navy-light: #2a5a8f;--teal: #1a4f6e;--bg: #eef1f5;--white: #ffffff;--text: #333333;--text-light: #666666;--text-muted: #999999;--border: #dde1e6;--accent: #2196F3;--accent-hover: #1976D2;--temp-hot: #e53935;--temp-warm: #ff9800;--temp-cool: #2196F3;--rain: #4CAF50;--rain-heavy: #1B5E20;--table-header: #2c4a6e;--table-alt: #f7f9fb;--shadow: 0 1px 3px rgba(0,0,0,.1);--shadow-lg: 0 4px 12px rgba(0,0,0,.12)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.header{background:var(--navy);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0003}.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;height:56px}.header-logo{text-decoration:none;display:flex;align-items:center}.header-logo:hover{text-decoration:none;opacity:.9}.header-logo-img{height:36px;width:auto}.home-headline{font-size:1.25rem;font-weight:600;color:var(--navy);margin:0 0 .75rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.header-nav{display:flex;gap:0;list-style:none;height:56px}.header-nav a{color:#ffffffd9;text-decoration:none;padding:0 1rem;height:56px;display:flex;align-items:center;font-size:.9rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;transition:background .15s,color .15s;border-bottom:3px solid transparent}.header-nav a:hover,.header-nav a.active{background:#ffffff14;color:#fff;border-bottom-color:#64b5f6;text-decoration:none}.hamburger{display:none;background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem}.breadcrumb-bar{background:#fff;border-bottom:1px solid var(--border);padding:.5rem 1rem}.breadcrumb{max-width:1200px;margin:0 auto;font-size:.8rem;color:var(--text-muted)}.breadcrumb a{color:var(--text-light)}.breadcrumb span{margin:0 .35rem}.page-title-bar{background:#fff;border-bottom:1px solid var(--border);padding:.75rem 1rem}.page-title-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.page-title{font-size:1.4rem;font-weight:700;color:var(--navy)}.main{max-width:1200px;margin:0 auto;padding:1.25rem 1rem}.card{background:var(--white);border:1px solid var(--border);border-radius:4px;box-shadow:var(--shadow);margin-bottom:1.25rem;overflow:hidden}.card-header{padding:.75rem 1rem;font-weight:600;font-size:1rem;color:var(--navy);border-bottom:1px solid var(--border);margin:0;background:#f8f9fa}.card-body{padding:1rem}.now-panel{position:relative;color:#fff;border-radius:4px;padding:1.5rem;box-shadow:var(--shadow-lg);background:url("./media/port-douglas-bg-H7KFGZ5J.jpg") center center / cover no-repeat;overflow:hidden}.now-panel:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#0f2037bf,#14505aa6);z-index:0}.now-panel>*{position:relative;z-index:1}.now-header{display:flex;align-items:baseline;gap:1rem;margin-bottom:1rem}.now-label{font-size:1.5rem;font-weight:700}.now-updated{font-size:.8rem;color:#ffffffb3;text-transform:uppercase}.now-temp-row{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:.25rem;align-items:end}.now-temp{font-size:3.5rem;font-weight:300;line-height:1}.now-wbgt-block{display:flex;flex-direction:column;justify-content:flex-end}.now-wbgt{font-size:1.1rem;font-weight:500;line-height:1.2}.now-temp .trend{font-size:1.8rem;font-weight:700;vertical-align:super}.now-temp .trend.up{color:#ef9a9a}.now-temp .trend.down{color:#90caf9}.now-grid,.now-grid-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:1.25rem}.now-item{padding:.5rem 0}.now-item-label{font-size:.7rem;text-transform:uppercase;color:#fff9;letter-spacing:.05em;margin-bottom:.15rem}.now-item-link{color:inherit;text-decoration:none;border-bottom:1px dotted rgba(255,255,255,.3)}.now-item-link:hover{color:#ffffffe6;border-bottom-color:#fff9}.now-item-value{font-size:1.1rem;font-weight:600}.now-item-detail{font-size:.65rem;color:#ffffff80;margin-top:.1rem}.now-item-value .trend{font-size:.95rem;font-weight:700;margin-left:.25rem}.now-item-value .trend.up{color:#ef9a9a}.now-item-value .trend.down{color:#90caf9}.now-wind-arrow{vertical-align:middle;margin-right:2px}.pulse-up,.pulse-down{border-radius:4px;padding:2px 6px;margin:-2px -6px}.pulse-up{animation:pulseRedBox 10s linear forwards}.pulse-down{animation:pulseBlueBox 10s linear forwards}.now-temp.pulse-up{border-radius:8px;padding:4px 12px;margin:-4px -12px;animation:pulseRedBox 10s linear forwards}.now-temp.pulse-down{border-radius:8px;padding:4px 12px;margin:-4px -12px;animation:pulseBlueBox 10s linear forwards}@keyframes pulseRedBox{0%{background:#ff3c3c4d;box-shadow:0 0 18px #ff3c3cb3,inset 0 0 8px #ff3c3c26;border:1px solid rgba(255,60,60,.8);color:#ff6b6b}8%{background:#ff3c3c0f;box-shadow:0 0 4px #ff3c3c26;border:1px solid rgba(255,60,60,.2);color:#ff6b6b}16%{background:#ff3c3c42;box-shadow:0 0 16px #ff3c3c99,inset 0 0 6px #ff3c3c1f;border:1px solid rgba(255,60,60,.7);color:#ff6b6b}24%{background:#ff3c3c0d;box-shadow:0 0 3px #ff3c3c1f;border:1px solid rgba(255,60,60,.18);color:#ff6b6b}32%{background:#ff3c3c38;box-shadow:0 0 14px #ff3c3c80,inset 0 0 6px #ff3c3c1a;border:1px solid rgba(255,60,60,.6);color:#ff8a8a}40%{background:#ff3c3c0a;box-shadow:0 0 3px #ff3c3c1a;border:1px solid rgba(255,60,60,.15);color:#ff8a8a}48%{background:#ff3c3c29;box-shadow:0 0 10px #ff3c3c66,inset 0 0 4px #ff3c3c14;border:1px solid rgba(255,60,60,.5);color:#ff8a8a}56%{background:#ff3c3c08;box-shadow:0 0 2px #ff3c3c14;border:1px solid rgba(255,60,60,.12);color:#ff8a8a}64%{background:#ff3c3c1a;box-shadow:0 0 8px #ff3c3c4d;border:1px solid rgba(255,60,60,.35);color:#ff8a8a}75%{background:#ff3c3c05;box-shadow:none;border:1px solid rgba(255,60,60,.08);color:inherit}to{background:transparent;box-shadow:none;border:1px solid transparent;color:inherit}}@keyframes pulseBlueBox{0%{background:#3c8cff4d;box-shadow:0 0 18px #3c8cffb3,inset 0 0 8px #3c8cff26;border:1px solid rgba(60,140,255,.8);color:#64b5f6}8%{background:#3c8cff0f;box-shadow:0 0 4px #3c8cff26;border:1px solid rgba(60,140,255,.2);color:#64b5f6}16%{background:#3c8cff42;box-shadow:0 0 16px #3c8cff99,inset 0 0 6px #3c8cff1f;border:1px solid rgba(60,140,255,.7);color:#64b5f6}24%{background:#3c8cff0d;box-shadow:0 0 3px #3c8cff1f;border:1px solid rgba(60,140,255,.18);color:#64b5f6}32%{background:#3c8cff38;box-shadow:0 0 14px #3c8cff80,inset 0 0 6px #3c8cff1a;border:1px solid rgba(60,140,255,.6);color:#90caf9}40%{background:#3c8cff0a;box-shadow:0 0 3px #3c8cff1a;border:1px solid rgba(60,140,255,.15);color:#90caf9}48%{background:#3c8cff29;box-shadow:0 0 10px #3c8cff66,inset 0 0 4px #3c8cff14;border:1px solid rgba(60,140,255,.5);color:#90caf9}56%{background:#3c8cff08;box-shadow:0 0 2px #3c8cff14;border:1px solid rgba(60,140,255,.12);color:#90caf9}64%{background:#3c8cff1a;box-shadow:0 0 8px #3c8cff4d;border:1px solid rgba(60,140,255,.35);color:#90caf9}75%{background:#3c8cff05;box-shadow:none;border:1px solid rgba(60,140,255,.08);color:inherit}to{background:transparent;box-shadow:none;border:1px solid transparent;color:inherit}}.recently-table{width:100%;border-collapse:collapse;font-size:.9rem}.recently-table thead th{background-color:var(--table-header);color:#fff;padding:.5rem .4rem;text-align:center;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em}.recently-table thead th small{font-weight:400;opacity:.8;text-transform:none}.recently-table tbody td{padding:.5rem .4rem;text-align:center;border-bottom:1px solid #e8eaed}.recently-table tbody tr:last-child td{border-bottom:none}.recently-table tbody tr:hover{background-color:#00000005}.recently-table tbody tr.dodgy-day td{color:#bbb}.temp-time{font-size:.7rem;color:#999;font-weight:400;margin-top:1px}.today-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:1rem}.summary-item{text-align:center;padding:.75rem}.summary-item-label{font-size:.75rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.03em;margin-bottom:.25rem}.summary-item-value{font-size:1.5rem;font-weight:600;color:var(--navy)}.summary-item-detail{font-size:.75rem;color:var(--text-light);margin-top:.15rem}.home-top{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}@media(max-width:700px){.home-top{grid-template-columns:1fr}}.view-link{font-size:.85rem;color:var(--accent);text-decoration:none;font-weight:500}.view-link:hover{text-decoration:underline}.card-footer-link{text-align:right;padding:.4rem 1rem .6rem}.now-footer-link{text-align:right;padding-top:.5rem}.now-footer-link .view-link{color:#ffffffb3}.now-footer-link .view-link:hover{color:#fff}.warnings-card{border-left:4px solid #d32f2f}.warnings-body{padding:.75rem 1rem;font-weight:600}.placeholder-card{text-align:center;padding:2rem;color:var(--text-muted);font-style:italic}.date-nav{display:flex;align-items:center;gap:4px;position:relative}.date-nav .btn-latest{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:6px;height:36px;padding:0 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s;margin-left:4px}.date-nav .btn-latest:hover{background:var(--accent-hover)}.day-grid-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.day-grid-header span{font-weight:700;font-size:1rem;color:var(--navy)}.day-grid-header button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--navy);padding:2px 8px;border-radius:4px;transition:background .15s}.day-grid-header button:hover{background:var(--bg)}.day-grid-header button:disabled{opacity:.3;cursor:default}.day-grid-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.day-grid-weekdays span{font-size:.75rem;font-weight:600;color:var(--text-light);text-align:center;padding:2px 0}.day-grid-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.day-grid-days button{background:#fff;border:1px solid var(--border);border-radius:6px;padding:6px 2px;font-size:.85rem;cursor:pointer;color:var(--text);transition:all .15s}.day-grid-days button:hover:not(:disabled){background:var(--bg);border-color:var(--accent)}.day-grid-days button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.day-grid-days button:disabled{opacity:.25;cursor:default}.day-grid-days .day-empty{border:none;background:none;cursor:default}.month-nav{display:flex;align-items:center;gap:4px;position:relative}.month-arrow{background:#fff;border:1px solid var(--border);border-radius:6px;width:36px;height:36px;font-size:1.2rem;cursor:pointer;color:var(--navy);display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.month-arrow:hover{background:var(--bg);border-color:var(--accent)}.month-arrow:disabled{opacity:.3;cursor:default;border-color:var(--border);background:#fff}.month-display{background:#fff;border:1px solid var(--border);border-radius:6px;padding:0 1.25rem;height:36px;font-size:.95rem;font-weight:600;color:var(--navy);cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap;min-width:160px;text-align:center}.month-display:hover{background:var(--bg);border-color:var(--accent)}.month-display.open{border-color:var(--accent);background:var(--bg)}.month-grid-dropdown{display:none;position:absolute;top:calc(100% + 6px);left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:12px;z-index:100;min-width:260px}.month-grid-dropdown.open{display:block}.month-grid-year{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.month-grid-year span{font-weight:700;font-size:1rem;color:var(--navy)}.month-grid-year button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--navy);padding:2px 8px;border-radius:4px;transition:background .15s}.month-grid-year button:hover{background:var(--bg)}.month-grid-year button:disabled{opacity:.3;cursor:default}.month-grid-months{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.month-grid-months button{background:#fff;border:1px solid var(--border);border-radius:6px;padding:8px 4px;font-size:.85rem;cursor:pointer;color:var(--text);transition:all .15s}.month-grid-months button:hover:not(:disabled){background:var(--bg);border-color:var(--accent)}.month-grid-months button.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.month-grid-months button:disabled{opacity:.25;cursor:default}.month-nav .btn-latest{background:var(--accent);color:#fff;border:1px solid var(--accent);border-radius:6px;height:36px;padding:0 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s;margin-left:4px}.month-nav .btn-latest:hover{background:var(--accent-hover)}.chart-container{position:relative;width:100%;height:300px;padding:.5rem 0;margin:0 -1rem;width:calc(100% + 2rem)}.chart-container canvas{width:100%!important;max-height:100%}.chart-title{text-align:center;font-weight:600;font-size:1rem;color:var(--text);margin-bottom:.5rem}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}table.obs-table{width:100%;border-collapse:collapse;font-size:.85rem}table.obs-table thead th{background:var(--table-header);color:#fff;padding:.6rem .5rem;text-align:center;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.02em;cursor:pointer;-webkit-user-select:none;user-select:none;border-right:1px solid rgba(255,255,255,.15)}table.obs-table thead th:last-child{border-right:none}table.obs-table thead th:hover{background:var(--navy-light)}table.obs-table tbody td{padding:.5rem .75rem;text-align:center;border-bottom:1px solid var(--border);white-space:nowrap}table.obs-table tbody tr:nth-child(2n){background:var(--table-alt)}table.obs-table tbody tr:hover{background:#e3f2fd}.temp-below-n5{color:#8a50c8;font-weight:600}.temp-n5-0{color:#5a9fc8;font-weight:600}.temp-0-5{color:#3a8db8;font-weight:600}.temp-5-10{color:#3a8a5a;font-weight:600}.temp-10-15{color:#6a8a20;font-weight:600}.temp-15-20{color:#9a8a10;font-weight:600}.temp-20-25{color:#b08a18;font-weight:600}.temp-25-30{color:#c06820;font-weight:600}.temp-30-35{color:#c05a20;font-weight:600}.temp-35-40{color:#a04810;font-weight:600}.temp-40-45{color:#c03020;font-weight:600}.temp-45plus{color:#5b3695;font-weight:600}.wind-0-10{color:#6482cf;font-weight:600}.wind-10-16{color:#50c864;font-weight:600}.wind-16-21{color:#d2d23c;font-weight:600}.wind-21-33{color:orange;font-weight:600}.wind-33-47{color:#dc1e1e;font-weight:600}.wind-47plus{color:#8c1e8c;font-weight:600}.rain-02-5{color:#00b0b0;font-weight:600}.rain-5-10{color:green;font-weight:600}.rain-10-25{color:#b0a000;font-weight:600}.rain-25-50{color:#d07000;font-weight:600}.rain-50-100{color:#c00;font-weight:600}.rain-100plus{color:#d0d;font-weight:600}.temp-bg-below-n5{background:#7b4bc4!important}.temp-bg-n5-0{background:#7eaed4!important}.temp-bg-0-5{background:#6db8d4!important}.temp-bg-5-10{background:#5bb88a!important}.temp-bg-10-15{background:#8bb848!important}.temp-bg-15-20{background:#c4b830!important}.temp-bg-20-25{background:#dba228!important}.temp-bg-25-30{background:#e88c1a!important}.temp-bg-30-35{background:#e06818!important}.temp-bg-35-40{background:#d04418!important}.temp-bg-40-45{background:#b82020!important}.temp-bg-45plus{background:#8a2890!important}.dew-bg-below0{background:#cc3c3c4d!important}.dew-bg-0-5{background:#dc787840!important}.dew-bg-5-10{background:#e6aaaa40!important}.dew-bg-10-15{background:#ebdce64d!important}.dew-bg-15-20{background:#b4b4dc4d!important}.dew-bg-20-24{background:#6482d240!important}.dew-bg-24-26{background:#4664c84d!important}.dew-bg-26plus{background:#3caa5059!important}.solar-bg-0{background:#50505040!important}.solar-bg-200{background:#a0967840!important}.solar-bg-400{background:#d2be3c4d!important}.solar-bg-650{background:#f0af2861!important}.solar-bg-1000{background:#ff960073!important}.wbgt-low{color:#4caf50}.wbgt-moderate{color:#c8a600}.wbgt-high{color:#ff9800}.wbgt-extreme{color:#f44336}.wbgt-dangerous{color:#9c27b0}.wind-bg-0-10{background:#6482cf33!important}.wind-bg-10-16{background:#50c86433!important}.wind-bg-16-21{background:#d2d23c33!important}.wind-bg-21-33{background:#ffa50040!important}.wind-bg-33-47{background:#dc1e1e40!important}.wind-bg-47plus{background:#8c1e8c40!important}.rain-bg-02-5{background:#0ff3!important}.rain-bg-5-10{background:#00800033!important}.rain-bg-10-25{background:#ffff0040!important}.rain-bg-25-50{background:#ffa50040!important}.rain-bg-50-100{background:#ff000040!important}.rain-bg-100plus{background:#ff00ff40!important}.sky-sunny{background:#ffe082!important}.sky-mostly-sunny{background:#fff8e1!important}.sky-sun-cloud{background:#f5f5f5!important}.sky-mostly-cloudy{background:#d5dbe0!important}.sky-overcast{background:#cfd8dc!important}.cell-highlight-cool{background:#2196f31a!important}.cell-highlight-warm{background:#e539351a!important}.cell-highlight-rain{background:#4caf5026!important}table.obs-table tbody tr.totals-row{background:#f0f4f8;font-weight:600;border-top:2px solid var(--navy)}.climate-table{font-size:.8rem}.climate-table th,.climate-table td{padding:.35rem .4rem;text-align:center;white-space:nowrap}.climate-table td[title]{cursor:help;text-decoration:underline dotted;text-underline-offset:2px}.climate-table td.climate-label{text-align:left;font-weight:600;color:var(--navy);white-space:nowrap;padding-right:.75rem}.climate-current-month{border-left:2px solid rgba(76,175,80,.5)!important;border-right:2px solid rgba(76,175,80,.5)!important}thead .climate-current-month{background:#4caf5026!important;border-top:2px solid rgba(76,175,80,.5)!important}tbody tr:last-child td.climate-current-month{border-bottom:2px solid rgba(76,175,80,.5)!important}.station-info{padding:1rem;border-top:1px solid var(--border);color:var(--text-light);font-size:.85rem}.station-name{font-weight:700;color:var(--navy);font-size:1rem;margin-bottom:.25rem}.footer{background:var(--navy-dark);color:#ffffffb3;padding:2rem 1rem;margin-top:2rem;font-size:.85rem}.footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-nav{display:flex;gap:1.5rem;flex-wrap:wrap}.footer-info{text-align:right}.footer a{color:#90caf9}.loading{text-align:center;padding:3rem;color:var(--text-muted)}.spinner{display:inline-block;width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{background:#fff3e0;border:1px solid #ffcc80;padding:1rem;border-radius:4px;color:#e65100;text-align:center}.chart-footer{display:flex;align-items:center;justify-content:center;margin-top:8px;position:relative}.chart-updated{position:absolute;right:0;font-size:.75rem;color:var(--text-muted)}.chart-csv-btn{position:absolute;left:0;font-size:.7rem;padding:2px 8px;border:1px solid var(--border);border-radius:3px;background:var(--card-bg);color:var(--text-muted);cursor:pointer;font-weight:600;letter-spacing:.5px}.chart-csv-btn:hover{background:var(--border);color:var(--text)}.chart-range-buttons{display:flex;justify-content:center;gap:6px}.chart-range-buttons button{padding:4px 14px;border:1px solid #ccc;border-radius:4px;background:#f5f5f5;color:#555;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.chart-range-buttons button:hover{background:#e0e0e0}.chart-range-buttons button.active{background:var(--navy);color:#fff;border-color:var(--navy)}@media(max-width:768px){.header-nav{display:none;flex-direction:column;position:absolute;top:56px;left:0;right:0;background:var(--navy);border-top:1px solid rgba(255,255,255,.1);box-shadow:0 4px 8px #0003;height:auto}.header-nav.open{display:flex}.header-nav a{height:auto;padding:.9rem 1.25rem;border-bottom:1px solid rgba(255,255,255,.05);border-left:3px solid transparent}.header-nav a:hover,.header-nav a.active{border-bottom-color:#ffffff0d;border-left-color:#64b5f6}.hamburger{display:block}.chart-container{height:250px}.now-temp{font-size:2.5rem}.now-wbgt{font-size:.95rem}.page-title{font-size:1.15rem}.page-title-inner{flex-direction:column;align-items:flex-start}.footer-inner{flex-direction:column;text-align:center}.footer-nav{justify-content:center}.footer-info{text-align:center}}.feedback-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.85rem;font-weight:600;color:var(--navy)}.form-group input[type=text],.form-group input[type=email],.form-group select,.form-group textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;font-family:inherit;color:var(--text);background:#fff;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #2196f31f}.form-group textarea{resize:vertical;min-height:100px}.word-counter{font-size:.75rem;color:var(--text-muted);text-align:right}.word-counter.over-limit{color:#e53935;font-weight:600}.submit-btn{align-self:flex-start;padding:.65rem 2rem;background:var(--navy);color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.submit-btn:hover{background:var(--navy-light)}.feedback-success{text-align:center;padding:2rem 1rem;color:var(--navy)}@media(max-width:480px){.now-grid,.today-summary{grid-template-columns:repeat(2,1fr)}}.forecast-cards{display:inline-flex;gap:0;overflow-x:auto;max-width:100%;padding:0;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;border:1px solid var(--border);border-radius:8px;background:var(--white)}.daily-scroll-btn{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:26px;height:100%;max-height:280px;border:none;background:#f0f3f8d9;color:var(--navy);font-size:1.6rem;font-weight:300;cursor:pointer;align-items:center;justify-content:center;transition:background .15s}.daily-scroll-btn:hover{background:#dce1ebf2}.daily-scroll-left{left:0;border-radius:8px 0 0 8px}.daily-scroll-right{right:0;border-radius:0 8px 8px 0}@media(max-width:960px){.daily-scroll-btn{display:flex}}.forecast-card{flex:0 0 130px;scroll-snap-align:start;border:none;border-right:1px solid var(--border);border-radius:0;padding:.6rem .5rem;text-align:center;cursor:pointer;transition:background .15s;background:transparent}.forecast-card:last-child{border-right:none}.forecast-card:hover{background:#2196f30d;box-shadow:none}.forecast-card.active{background:#eef3f9;border-color:var(--border);box-shadow:none}.fc-day{font-weight:700;font-size:.85rem;color:var(--text)}.fc-date{font-size:.75rem;color:var(--text-muted);margin-bottom:.4rem}.fc-icon{font-size:2rem;line-height:1.2}.wx-icon{width:32px;height:32px;vertical-align:middle}.wx-icon-anim{width:50px;height:50px}.wx-icon-lg{width:56px;height:56px;margin:.25rem 0}.fc-desc{font-size:.7rem;color:var(--text-light);margin-bottom:.4rem;min-height:1.8em}.fc-temps{font-size:1.15rem;font-weight:700;margin-bottom:.3rem}.fc-min{opacity:.55;margin-left:.25rem}.fc-rain{font-size:.75rem;color:var(--text-light);margin-bottom:.2rem}.fc-rain-prob{color:#1565c0;font-weight:600}.fc-rain-amt,.fc-rain-nil{color:var(--text-muted)}.fc-heat{font-size:.8rem;display:flex;justify-content:center;gap:.6rem}.fc-dewpoint{color:var(--accent)}.fc-wbgt{font-weight:600}.fc-wind{font-size:.8rem}.fc-wind-unit{font-size:.65rem;color:var(--text-muted)}.fc-sun{margin-top:.3rem;padding-top:.3rem;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:0 .2rem;font-size:.6rem;line-height:1.4}.fc-sun-item{text-align:center;white-space:nowrap}.fc-sun-lbl{color:var(--text-muted);text-transform:uppercase;font-size:.55rem;display:block}.fc-sun-val{font-weight:600;color:var(--text);font-size:.65rem}.forecast-combined{overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.forecast-charts-embedded{padding:.5rem 0}.forecast-chart-wrap{position:relative;height:280px;margin-bottom:0}.forecast-chart-wrap:last-child{margin-bottom:0}.fc-range-toggle{display:flex;gap:0;border:1px solid var(--border);border-radius:4px;overflow:hidden}.fc-range-btn{padding:.25rem .75rem;font-size:.75rem;font-weight:600;border:none;background:var(--white);color:var(--text-light);cursor:pointer;transition:all .15s}.fc-range-btn:not(:last-child){border-right:1px solid var(--border)}.fc-range-btn.active{background:var(--navy);color:var(--white)}.fc-range-btn:hover:not(.active){background:#f0f3f8}@media(max-width:768px){.forecast-charts-embedded{display:none}}.forecast-source{margin-top:.75rem;font-size:.7rem;color:var(--text-muted);text-align:right}.forecast-source a{color:var(--accent)}.section-title{font-size:1.1rem;font-weight:600;color:var(--navy);margin:1.25rem 0 .5rem;padding:0}.hourly-strip-header{display:flex;align-items:center;flex-wrap:wrap;padding:.6rem 1rem 0;gap:.75rem;border-bottom:3px solid var(--navy)}.hourly-strip-header .card-header{margin:0;padding:0;border:none;font-size:1rem;font-weight:800;color:var(--navy);letter-spacing:.03em}.hourly-summary{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:600}.hs-badge{display:inline-block;padding:3px 12px;border-radius:4px;font-size:.85rem;font-weight:700;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.2)}.hs-rain-summary{color:var(--navy);font-weight:700;font-size:.85rem}.forecast-text{padding:.6rem 1rem .5rem;font-size:.88rem;line-height:1.5;color:var(--text);border-bottom:1px solid var(--border)}.hourly-strip-wrapper{position:relative;padding:0}.hourly-strip{display:flex;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;gap:0;padding-left:20px;border:1px solid #d0d5dc;border-top:none;border-radius:0 0 8px 8px;background:#f8fafd}.hourly-strip::-webkit-scrollbar{height:6px}.hourly-strip::-webkit-scrollbar-thumb{background:#bbb;border-radius:3px}.hs-col{flex:0 0 80px;min-width:80px;border-left:1px solid #e4e8ed;text-align:center}.hs-col:first-child{border-left:none}.hs-cell{display:flex;align-items:center;justify-content:center;min-height:40px;padding:4px 6px;font-size:.8rem;line-height:1.2}.hs-time{font-weight:700;font-size:.82rem;color:var(--navy);background:#edf0f4;min-height:32px}.hs-icon{min-height:46px}.hs-icon .wx-icon{width:34px;height:34px}.hs-temp-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:.9rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);min-width:52px}.hs-rainp{font-size:.78rem;min-height:34px}.hs-rainp-active{font-weight:600;color:var(--navy)}.hs-rainp-nil{color:var(--text-muted);font-size:.75rem}.hs-precip{min-height:42px}.hs-precip-badge{display:inline-block;padding:3px 6px;border-radius:4px;font-size:.78rem;font-weight:700;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.15);min-width:44px;line-height:1.25}.hs-precip-trace{font-size:.72rem;color:var(--text-light);line-height:1.25}.hs-precip-nil{font-size:.8rem;color:var(--text-muted)}.hs-wind{flex-direction:column;gap:1px;font-size:.82rem;font-weight:600;min-height:48px}.hs-wind svg{flex-shrink:0}.hs-wind-val{display:inline;font-weight:700}.hs-wind-unit{font-size:.65rem;color:var(--text-muted);font-weight:400}.hourly-scroll-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:26px;height:100%;max-height:280px;border:none;background:#f0f3f8d9;color:var(--navy);font-size:1.6rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.hourly-scroll-btn:hover{background:#dce1ebf2}.hourly-scroll-left{left:0;border-radius:0 0 0 8px}.hourly-scroll-right{right:0;border-radius:0 0 8px}@media(max-width:768px){.forecast-card{flex:0 0 110px;padding:.5rem .3rem}.fc-icon{font-size:1.6rem}.wx-icon-lg{width:44px;height:44px}.fc-temps{font-size:1rem}}
