:root{
  --water-deep:#0ea5e9;
  --water-mid:#38bdf8;
  --water-light:#7dd3fc;
  --water-surface:#e0f2fe;
  --forest:#166534;
  --forest-light:#22c55e;
  --earth:#78716c;
  --sand:#fef3c7;
  --sky:#f0f9ff;
  --bg-gradient:linear-gradient(135deg, #e0f2fe 0%, #fef3c7 50%, #f0fdfa 100%);
  --card-bg:#ffffff;
  --text-primary:#1e293b;
  --text-secondary:#64748b;
  --text-muted:#94a3b8;
  --shadow-sm:0 1px 3px rgba(14,165,233,0.08);
  --shadow-md:0 4px 12px rgba(14,165,233,0.12);
  --shadow-lg:0 10px 40px rgba(14,165,233,0.18);
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100vw}
body{
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg-gradient);
  color:var(--text-primary);
  min-height:100vh;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
body::before{
  content:'';
  position:fixed;
  top:0;left:0;right:0;bottom:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%230ea5e9' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  pointer-events:none;
  z-index:-1;
}
.topbar{
  position:sticky;
  top:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  background:linear-gradient(135deg, var(--water-deep) 0%, #0284c7 100%);
  box-shadow:0 4px 20px rgba(14,165,233,0.3);
  gap:10px;
}
.brand{display:flex;align-items:center;gap:12px;cursor:pointer}
.logo{
  width:44px;height:44px;
  border-radius:12px;
  background:linear-gradient(145deg, #ffffff 0%, #e0f2fe 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
  box-shadow:0 4px 12px rgba(0,0,0,0.15);
  animation:float 3s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}
.title{
  font-size:18px;
  font-weight:800;
  color:#fff;
  text-shadow:0 2px 4px rgba(0,0,0,0.1);
  letter-spacing:-0.5px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:180px;
}
.subtitle{
  font-size:11px;
  color:rgba(255,255,255,0.85);
  font-weight:500;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:180px;
}
.right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.pill{
  padding:6px 12px;
  border-radius:20px;
  background:rgba(255,255,255,0.2);
  backdrop-filter:blur(10px);
  color:#fff;
  font-size:11px;
  font-weight:600;
  border:1px solid rgba(255,255,255,0.15);
  white-space:nowrap;
}
.btn{
  border:0;
  border-radius:10px;
  padding:10px 18px;
  font-weight:700;
  font-size:13px;
  cursor:pointer;
  transition:all 0.25s cubic-bezier(0.4,0,0.2,1);
  text-transform:uppercase;
  letter-spacing:0.5px;
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:'Segoe UI',system-ui,sans-serif;
}
.btn.primary{
  background:linear-gradient(135deg, #22c55e 0%, #16a34a 100%) !important;
  color:#fff !important;
  box-shadow:0 4px 15px rgba(34,197,94,0.35);
  min-width:100px;
  font-weight:900 !important;
  text-shadow:0 1px 2px rgba(0,0,0,0.3) !important;
  font-size:14px !important;
  line-height:1.2 !important;
  height:auto !important;
  -webkit-text-fill-color:#fff !important;
}
.btn.primary:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(34,197,94,0.45);
}
.btn.primary:active{transform:translateY(0)}
.btn.ghost{
  background:rgba(255,255,255,0.15);
  color:#fff;
  border:1px solid rgba(255,255,255,0.2);
}
.btn.ghost:hover{background:rgba(255,255,255,0.25)}
.btn:disabled{opacity:0.6;cursor:not-allowed;transform:none}
.btn.big{padding:12px 24px;font-size:15px}
.container{max-width:1300px;margin:0 auto;padding:12px}

.fishing-score-card{
  background:linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
  border-radius:var(--radius-lg);
  padding:20px;
  margin-bottom:16px;
  color:#fff;
}
.score-main{text-align:center;margin-bottom:16px}
.score-label{font-size:11px;color:rgba(255,255,255,0.6);letter-spacing:1px;margin-bottom:4px}
.score-value{font-size:56px;font-weight:900;line-height:1}
.score-max{font-size:24px;color:rgba(255,255,255,0.4)}
.score-rating{font-size:18px;font-weight:700;margin-top:4px}
.score-rating.excellent{color:#ef4444}
.score-rating.good{color:#22c55e}
.score-rating.fair{color:#f59e0b}
.score-rating.poor{color:#94a3b8}

.score-details{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:14px;
}
.detail-row{
  background:rgba(255,255,255,0.08);
  padding:10px 12px;
  border-radius:10px;
  display:flex;
  align-items:center;
  gap:8px;
}
.detail-icon{font-size:16px}
.detail-label{font-size:12px;color:rgba(255,255,255,0.6)}
.detail-value{font-size:13px;font-weight:700;margin-left:auto}

.score-prime{
  background:linear-gradient(135deg, #0ea5e9 0%, #0284c7 100%);
  border-radius:12px;
  padding:14px;
  text-align:center;
  margin-bottom:12px;
}
.prime-title{font-size:11px;color:rgba(255,255,255,0.7);margin-bottom:4px}
.prime-times{font-size:18px;font-weight:800}

.score-tip{font-size:13px;color:rgba(255,255,255,0.6);text-align:center;font-style:italic}

.grid-2col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:14px;
}
.water-chart-card .cardTitle,
.moon-card .cardTitle{font-size:13px;margin-bottom:12px}

.tide-legend{text-align:center;font-size:12px;color:var(--text-secondary);margin-top:8px}

.moon-display{text-align:center;padding:16px 0}
.moon-icon-lg{font-size:64px;line-height:1}
.moon-name{font-size:18px;font-weight:700;margin-top:8px}
.moon-illum{font-size:13px;color:var(--text-secondary)}
.moon-age{font-size:12px;color:var(--text-muted)}
.moon-tip{
  background:linear-gradient(135deg, #1e293b 0%, #0f172a 100%);
  color:#fff;
  padding:12px;
  border-radius:10px;
  font-size:12px;
  text-align:center;
}

.weather-card .cardTitle{margin-bottom:10px}
.weather-summary{font-size:16px;font-weight:600;margin-bottom:14px}
.weather-charts{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.chart-box{}
.chart-label{font-size:11px;color:var(--text-secondary);margin-bottom:6px}

.section-title{font-size:16px;font-weight:700;margin:20px 0 10px;color:var(--text-primary)}

@media (max-width:768px){
  .grid-2col{grid-template-columns:1fr}
  .weather-charts{grid-template-columns:1fr}
  .fishing-score-card{padding:16px}
  .score-value{font-size:48px}
  .score-details{grid-template-columns:1fr}
}

.filters{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:14px;
}
.field{
  background:var(--card-bg);
  border-radius:var(--radius-lg);
  padding:12px 14px;
  box-shadow:var(--shadow-md);
  border:1px solid rgba(14,165,233,0.08);
  transition:all 0.3s ease;
}
.field:hover{box-shadow:var(--shadow-lg);border-color:rgba(14,165,233,0.2)}
.field.full{grid-column:1/-1}
label{
  display:block;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.8px;
  color:var(--text-secondary);
  margin-bottom:6px;
  font-weight:700;
}
select,input{
  width:100%;
  padding:10px 12px;
  border-radius:var(--radius-sm);
  border:2px solid #e2e8f0;
  background:#f8fafc;
  font-size:14px;
  font-weight:500;
  color:var(--text-primary);
  outline:none;
  transition:all 0.2s ease;
}
select:focus,input:focus{
  border-color:var(--water-mid);
  background:#fff;
  box-shadow:0 0 0 3px rgba(56,189,248,0.15);
}
.searchRow{display:flex;gap:8px}
.searchRow input{flex:1}
.searchRow .btn{padding:10px 14px}
.searchResults{
  margin-top:8px;
  max-height:150px;
  overflow-y:auto;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.searchItem{
  padding:10px 12px;
  border-radius:var(--radius-sm);
  border:1px solid #e2e8f0;
  background:#f8fafc;
  cursor:pointer;
  font-size:12px;
  transition:all 0.2s ease;
}
.searchItem:hover{
  background:var(--water-surface);
  border-color:var(--water-light);
  transform:translateX(4px);
}

.section-title{
  font-size:13px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--text-secondary);
  margin:20px 0 12px;
  display:flex;
  align-items:center;
  gap:10px;
}
.section-title::before{
  content:'';
  width:4px;height:18px;
  background:linear-gradient(180deg, var(--water-mid), var(--water-deep));
  border-radius:2px;
}

.grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
.card{
  background:var(--card-bg);
  border-radius:var(--radius-lg);
  padding:16px;
  box-shadow:var(--shadow-md);
  border:1px solid rgba(14,165,233,0.06);
  transition:all 0.3s ease;
}
.card:hover{box-shadow:var(--shadow-lg)}
.cardTitle{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:var(--text-secondary);
  margin-bottom:12px;
  display:flex;
  align-items:center;
  gap:8px;
}
.cardTitle::before{
  content:'';
  width:4px;height:14px;
  background:linear-gradient(180deg, var(--water-mid), var(--water-deep));
  border-radius:2px;
}
.hero{
  background:linear-gradient(145deg, #ffffff 0%, #f0f9ff 50%, #e0f2fe 100%);
  border:1px solid rgba(14,165,233,0.12);
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:'';
  position:absolute;
  top:-30%;right:-5%;
  width:200px;height:200px;
  background:radial-gradient(circle, rgba(56,189,248,0.12) 0%, transparent 70%);
  pointer-events:none;
}
.heroTop{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;position:relative;z-index:1}
.seg-info{flex:1;min-width:0}
.seg-title{
  font-size:12px;
  color:var(--text-secondary);
  font-weight:600;
  margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.seg-name{
  font-size:16px;
  font-weight:800;
  color:var(--text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.big{
  font-size:44px;
  font-weight:900;
  line-height:1.1;
  margin:10px 0 6px;
  background:linear-gradient(135deg, var(--water-deep), #0891b2);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.big-label{
  font-size:11px;
  color:var(--text-muted);
  font-weight:600;
}
.badge{
  padding:8px 14px;
  border-radius:20px;
  background:linear-gradient(135deg, var(--water-surface) 0%, var(--water-light) 100%);
  color:#0369a1;
  font-weight:800;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  box-shadow:0 2px 8px rgba(14,165,233,0.2);
  white-space:nowrap;
}
.heroBottom{
  display:flex;
  flex-direction:column;
  gap:12px;
  margin-top:16px;
  position:relative;z-index:1
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}
.stat-card{
  background:linear-gradient(145deg, #f8fafc 0%, #f1f5f9 100%);
  border-radius:var(--radius-md);
  padding:12px;
  border:1px solid #e2e8f0;
}
.stat-label{
  font-size:9px;
  text-transform:uppercase;
  letter-spacing:0.5px;
  color:var(--text-muted);
  font-weight:700;
  margin-bottom:2px;
}
.stat-value{
  font-size:13px;
  font-weight:800;
  color:var(--text-primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.stat-value.high{color:#16a34a}
.stat-value.medium{color:#ca8a04}
.stat-value.low{color:#dc2626}
.chip{
  padding:12px 16px;
  border-radius:var(--radius-md);
  background:linear-gradient(135deg, #dcfce7 0%, #bbf7d0 100%);
  color:#166534;
  font-weight:700;
  font-size:13px;
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(34,197,94,0.2);
}
.chip::before{content:'⭐';font-size:14px}
.insight{
  font-size:12px;
  color:var(--text-secondary);
  padding:10px 14px;
  background:#f8fafc;
  border-radius:var(--radius-sm);
  border-left:3px solid var(--water-mid);
  line-height:1.5;
}
.details summary{
  cursor:pointer;
  font-weight:700;
  color:var(--water-deep);
  font-size:12px;
  margin-top:10px;
  padding:8px 0;
  transition:color 0.2s;
}
.details summary:hover{color:#0891b2}
.pre{
  background:linear-gradient(145deg, #1e293b 0%, #0f172a 100%);
  color:#cbd5e1;
  padding:12px;
  border-radius:var(--radius-md);
  overflow:auto;
  font-size:11px;
  line-height:1.5;
  font-family:'Consolas','Monaco',monospace;
  margin-top:8px;
  max-height:200px;
}
.legend{margin-top:8px;color:var(--text-muted);font-size:11px;font-weight:500}

.timeline{
  display:flex;
  gap:8px;
  overflow-x:auto;
  padding:4px 0 8px;
  margin:-4px -4px 0;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  justify-content:flex-start;
  min-height:120px;
  align-items:center;
}
.timeline::-webkit-scrollbar{height:4px}
.timeline::-webkit-scrollbar-track{background:#f1f5f9;border-radius:2px}
.timeline::-webkit-scrollbar-thumb{background:var(--water-light);border-radius:2px}
.day-card{
  flex:0 0 auto;
  width:80px;
  padding:8px 6px;
  background:#f8fafc;
  border-radius:var(--radius-md);
  border:2px solid transparent;
  text-align:center;
  cursor:pointer;
  transition:all 0.2s ease;
}
.day-card:hover{transform:translateY(-2px);border-color:var(--water-light)}
.day-card.today{border-color:var(--water-deep);background:linear-gradient(145deg, #e0f2fe, #f0f9ff);box-shadow:0 4px 12px rgba(14,165,233,0.3)}
.day-card.past{opacity:0.65}
.day-card.selected{border-color:var(--forest-light);background:linear-gradient(145deg, #dcfce7, #f0fdf4)}
.day-card.forecast{background:linear-gradient(145deg, #f0fdf4, #ecfdf5)}
.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.day-weekday{font-size:9px;color:var(--text-muted);font-weight:700;text-transform:uppercase}
.day-rating{font-size:8px;font-weight:800;padding:2px 4px;border-radius:4px}
.day-rating.excellent{background:#16a34a;color:#fff}
.day-rating.good{background:#22c55e;color:#fff}
.day-rating.fair{background:#fbbf24;color:#fff}
.day-rating.poor{background:#ef4444;color:#fff}
.day-date{font-size:14px;font-weight:900;color:var(--text-primary);margin:2px 0}
.day-moon{font-size:14px;margin:2px 0}
.day-wli{font-size:13px;font-weight:800;color:var(--water-deep)}
.day-wli.low{color:#dc2626}
.day-wli.medium{color:#ca8a04}
.day-wli.high{color:#16a34a}
.day-lunar{font-size:8px;color:var(--text-muted)}
.day-weather{font-size:9px;color:var(--text-secondary);margin-top:2px}
.day-temps{font-size:8px;color:var(--text-muted)}
.day-turn{font-size:7px;color:var(--water-deep);font-weight:600}
.day-score{font-size:11px;font-weight:700;margin:4px 0;padding:3px 6px;border-radius:6px}
.day-score.excellent{background:#16a34a;color:#fff}
.day-score.good{background:#22c55e;color:#fff}
.day-score.fair{background:#fbbf24;color:#fff}
.day-score.poor{background:#ef4444;color:#fff}
.day-today-label{font-size:8px;font-weight:800;color:var(--water-deep);background:#e0f2fe;padding:2px 4px;border-radius:4px;margin-bottom:4px}

.timeline-detail{
  margin-top:12px;
}
.detail-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:16px;
}
.detail-date{
  font-size:14px;
  color:var(--text-secondary);
}
.detail-date-big{
  font-size:17px;
  font-weight:800;
}
.detail-score{
  font-size:14px;
  padding:8px 16px;
  border-radius:20px;
  font-weight:700;
  color:#fff;
}
.detail-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  margin-bottom:12px;
}
.detail-stat{
  background:#f8fafc;
  padding:10px;
  border-radius:var(--radius-sm);
}
.detail-stat-label{
  font-size:9px;
  color:var(--text-muted);
  text-transform:uppercase;
  font-weight:700;
}
.detail-stat-value{
  font-size:13px;
  font-weight:700;
  color:var(--text-primary);
}
.detail-weather{
  background:linear-gradient(135deg, #fef3c7, #f0f9ff);
  padding:12px;
  border-radius:var(--radius-md);
  margin-bottom:12px;
}
.detail-weather-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
}
.detail-weather-item{
  text-align:center;
}
.detail-moon{
  background:linear-gradient(135deg, #1e293b, #0f172a);
  padding:12px;
  border-radius:var(--radius-md);
  margin-bottom:12px;
  color:#fff;
}
.detail-fishing{
  background:#ecfdf5;
  padding:12px;
  border-radius:var(--radius-md);
}
.detail-prime{
  background:#dbeafe;
  padding:10px;
  border-radius:var(--radius-sm);
  margin-top:10px;
  font-size:11px;
  font-weight:700;
  color:#1e40af;
}

@media (max-width:480px){
  .day-card{width:75px}
  .detail-grid{grid-template-columns:1fr}
  .detail-weather-grid{grid-template-columns:repeat(2,1fr)}
  .topbar{flex-wrap:nowrap;gap:8px;padding:10px 12px}
  .brand{gap:8px}
  .logo{width:36px;height:36px;font-size:20px}
  .title{font-size:15px;max-width:120px}
  .subtitle{display:none}
  .right{flex-shrink:0;gap:8px}
  .pill{font-size:11px;padding:6px 8px}
  .btn{padding:8px 14px;font-size:13px;min-width:80px}
  .container{padding:10px;max-width:100%}
  .filters{grid-template-columns:1fr;gap:8px}
  .section-title{font-size:14px}
  .score-value{font-size:42px}
  .score-details{grid-template-columns:1fr}
  .detail-row{font-size:12px}
}

.moon-panel{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px;
  background:linear-gradient(145deg, #1e293b 0%, #0f172a 100%);
  border-radius:var(--radius-lg);
  color:#fff;
  margin-top:12px;
}
.moon-icon{font-size:42px;line-height:1}
.moon-info{flex:1}
.moon-phase{font-size:14px;font-weight:700;margin-bottom:2px}
.moon-illum{font-size:12px;color:rgba(255,255,255,0.7)}
.moon-details{font-size:11px;color:rgba(255,255,255,0.5);margin-top:4px}

.chart-section{
  margin-top:16px
}
.chart-wrap{
  position:relative;
  height:180px
}
.chart-wrap.small{height:140px}

.tabs{
  display:flex;
  gap:4px;
  background:#f1f5f9;
  padding:4px;
  border-radius:var(--radius-md);
  margin-bottom:12px;
}
.tab{
  flex:1;
  padding:10px 12px;
  border:none;
  background:transparent;
  border-radius:var(--radius-sm);
  font-size:12px;
  font-weight:700;
  color:var(--text-secondary);
  cursor:pointer;
  transition:all 0.2s;
  text-align:center;
}
.tab.active{
  background:#fff;
  color:var(--water-deep);
  box-shadow:0 2px 4px rgba(0,0,0,0.08);
}
.tab:hover:not(.active){color:var(--text-primary)}

.mapCard{padding:0;overflow:hidden}
.mapCard .cardTitle{padding:16px 16px 0 16px}
#map{height:350px;width:100%}

.water-indicator{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 8px;
  border-radius:10px;
  font-weight:700;
  font-size:11px;
}
.water-indicator.rising{background:#dcfce7;color:#166534}
.water-indicator.falling{background:#fee2e2;color:#dc2626}
.water-indicator.stable{background:#fef3c7;color:#ca8a04}

.solunar-card{background:linear-gradient(135deg, #1e1b4b 0%, #312e81 100%);color:#fff}
.solunar-display{padding:4px 0}
.solunar-rating{font-size:13px;font-weight:700;margin-bottom:10px}
.solunar-periods{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.solunar-major,.solunar-minor{background:rgba(255,255,255,0.1);padding:10px;border-radius:10px}
.solunar-title{font-size:10px;color:rgba(255,255,255,0.7);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.5px}
.solunar-times{font-size:14px;font-weight:800}
.solunar-tip{font-size:11px;color:rgba(255,255,255,0.6);text-align:center;font-style:italic}

.weather-extra{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.weather-extra-item{display:flex;align-items:center;gap:4px;padding:6px 10px;background:#f1f5f9;border-radius:8px;font-size:12px;font-weight:600}
.weather-extra-item span:first-child{font-size:14px}

@media (min-width:480px){
  .filters{grid-template-columns:repeat(3,1fr)}
  .field.full{grid-column:auto}
  .day-card{width:80px}
  .title{font-size:20px}
  .subtitle{font-size:12px}
}
@media (min-width:640px){
  .filters{grid-template-columns:repeat(5,1fr)}
  .grid{grid-template-columns:1.2fr 1fr}
  .grid .card:first-child{grid-column:1/-1}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .heroTop{gap:16px}
  .big{font-size:52px}
  .title{font-size:22px}
  .subtitle{font-size:13px}
  .topbar{padding:14px 24px}
  .container{padding:16px 20px}
  .section-title{margin:24px 0 14px}
  #map{height:420px}
  .chart-wrap{height:200px}
  .chart-wrap.small{height:150px}
  .day-card{width:85px}
  .timeline{gap:10px}
}
@media (min-width:1024px){
  .grid{grid-template-columns:1.15fr 1fr}
  .filters{grid-template-columns:repeat(5,1fr)}
  .day-card{width:90px}
  .moon-panel{padding:18px}
  .moon-icon{font-size:52px}
}

.solunar-rating-excellent{color:#16a34a}
.solunar-rating-good{color:#22c55e}
.solunar-rating-fair{color:#fbbf24}
.solunar-rating-poor{color:#ef4444}
