:root {
  --wind-calm:   #94a3b8;
  --wind-light:  #3b82f6;
  --wind-good:   #22c55e;
  --wind-strong: #f97316;
  --wind-danger: #ef4444;
}

.wind-module {
  padding-bottom: 80px;
}

/* ── Model selector ─────────────────────────────────────────── */
.wind-model-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.wind-model-btn {
  padding: 5px 12px;
  border: 1px solid var(--c-border);
  border-radius: 99px;
  background: var(--c-surface);
  color: var(--c-text);
  font-size: .8rem;
  font-weight: 500;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
}

.wind-model-btn:hover {
  border-color: var(--c-primary);
  color: var(--c-primary);
}

.wind-model-btn.active {
  background: var(--c-primary);
  border-color: var(--c-primary);
  color: #fff;
}

.wind-model-note {
  font-size: .85rem;
  color: var(--c-muted);
  font-style: italic;
  margin-top: 4px;
}

/* ── Search ─────────────────────────────────────────────────── */
.wind-search-wrap {
  position: relative;
  margin-bottom: 16px;
}

.wind-search-input {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-size: 1rem;
  background: var(--c-surface);
  color: var(--c-text);
  box-sizing: border-box;
  outline: none;
}

.wind-search-input:focus {
  border-color: var(--c-primary);
}

.wind-search-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  z-index: 200;
  box-shadow: 0 6px 16px rgba(0,0,0,.15);
  display: none;
  overflow: hidden;
}

.wind-search-item {
  padding: 10px 14px;
  cursor: pointer;
  display: flex;
  gap: 8px;
  align-items: baseline;
  font-size: .95rem;
}

.wind-search-item:hover {
  background: var(--c-bg);
}

.wind-no-results {
  cursor: default;
  color: var(--c-muted);
}

/* ── Current conditions ─────────────────────────────────────── */
.wind-current {
  background: var(--c-surface);
  border-radius: var(--r-lg);
  padding: 16px;
  margin-bottom: 16px;
}

.wind-loc-name {
  font-weight: 600;
  font-size: 1rem;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.wind-tz-badge {
  font-size: .75rem;
  font-weight: 500;
  padding: 2px 7px;
  border-radius: 99px;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  color: var(--c-muted);
  white-space: nowrap;
}

.wind-current-main {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.wind-big {
  font-size: 2.6rem;
  font-weight: 800;
  line-height: 1;
}

.wind-label-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 99px;
  font-size: .85rem;
  font-weight: 600;
  color: #fff;
}

.wind-current-details {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: .9rem;
  color: var(--c-muted);
  margin-bottom: 12px;
}

.wind-current-details strong {
  color: var(--c-text);
}

.wind-kite-rec {
  background: var(--c-bg);
  border-radius: var(--r-md);
  padding: 10px 14px;
  font-size: .95rem;
}

.wind-kite-rec strong {
  color: var(--c-primary);
  font-size: 1.1rem;
}

.wind-kite-rec--none {
  color: var(--c-muted);
  font-style: italic;
}

/* ── Day cards ──────────────────────────────────────────────── */
.wind-days {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wind-day-card {
  background: var(--c-surface);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.wind-day-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-border);
}

.wind-day-label {
  flex: 1;
  font-weight: 600;
  font-size: .95rem;
}

.wind-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 99px;
  font-size: .8rem;
  font-weight: 600;
  color: #fff;
}

.wind-kite-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 99px;
  font-size: .8rem;
  font-weight: 600;
  background: var(--c-primary);
  color: #fff;
}

.wind-wave-badge {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 99px;
  font-size: .8rem;
  font-weight: 600;
  background: #0ea5e9;
  color: #fff;
}

/* ── Tides ──────────────────────────────────────────────────── */
.wind-tides {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px 14px;
  background: color-mix(in srgb, #0ea5e9 8%, var(--c-surface));
  border-bottom: 1px solid var(--c-border);
}

.wind-tide-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .82rem;
  padding: 3px 8px;
  border-radius: var(--r-sm, 6px);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
}

.wind-tide-type {
  font-weight: 700;
  font-size: .78rem;
  letter-spacing: .03em;
}

.wind-tide-hw .wind-tide-type { color: #0ea5e9; }
.wind-tide-nw .wind-tide-type { color: #94a3b8; }

.wind-tide-time {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

.wind-tide-level {
  color: var(--c-muted);
  font-size: .78rem;
}

/* ── Table ──────────────────────────────────────────────────── */
.wind-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.wind-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .85rem;
  min-width: 320px;
}

.wind-table th {
  padding: 5px 8px;
  color: var(--c-muted);
  font-weight: 500;
  text-align: left;
  border-bottom: 1px solid var(--c-border);
  white-space: nowrap;
}

.wind-table td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--c-border);
  white-space: nowrap;
}

.wind-table tr:last-child td {
  border-bottom: none;
}

.wind-time {
  font-variant-numeric: tabular-nums;
  color: var(--c-muted);
}

.wind-dir {
  font-size: .8rem;
  font-weight: 500;
}

.wind-pp {
  color: #3b82f6;
  font-size: .82rem;
}

.wind-wave {
  color: #0ea5e9;
  font-size: .82rem;
}

.wind-muted {
  color: var(--c-muted);
}

/* ── Persönliche Kite-Badge + Empfehlung ────────────────────── */
.wind-kite-badge--std {
  background: var(--c-muted);
  opacity: .65;
  font-size: .72rem;
  padding: 2px 7px;
  margin-right: 3px;
}

.wind-kite-badge--pers {
  background: #8b5cf6;
  color: #fff;
  box-shadow: 0 0 0 2px color-mix(in srgb, #8b5cf6 25%, transparent);
}

.wind-kite-rec__pers {
  color: #8b5cf6;
  font-size: 1.1rem;
}

/* ── Session loggen Button ──────────────────────────────────── */
.wind-log-btn {
  margin-top: 10px;
  width: 100%;
  padding: 9px 14px;
  border: 1px dashed var(--c-border);
  border-radius: var(--r-md);
  background: transparent;
  color: var(--c-primary);
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}

.wind-log-btn:hover {
  background: color-mix(in srgb, var(--c-primary) 8%, transparent);
  border-color: var(--c-primary);
  border-style: solid;
}

/* ── Session-Form im Modal ──────────────────────────────────── */
.wind-session-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.wind-session-form label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: .85rem;
  font-weight: 500;
  color: var(--c-muted);
}

.wind-session-form input[type="text"],
.wind-session-form input[type="date"],
.wind-session-form input[type="number"],
.wind-session-form textarea {
  padding: 8px 10px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm, 6px);
  font-size: .95rem;
  background: var(--c-surface);
  color: var(--c-text);
  box-sizing: border-box;
  font-family: inherit;
}

.wind-session-form input:focus,
.wind-session-form textarea:focus {
  border-color: var(--c-primary);
  outline: none;
}

.wind-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.wind-power-choice {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 2px;
}

.wind-power-choice label {
  flex: 1;
  min-width: 90px;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm, 6px);
  cursor: pointer;
  background: var(--c-surface);
  color: var(--c-text);
  font-size: .85rem;
  font-weight: 500;
}

.wind-power-choice input[type="radio"] {
  accent-color: var(--c-primary);
}

.wind-rating-stars {
  display: flex;
  gap: 4px;
  font-size: 1.6rem;
  line-height: 1;
  color: #f59e0b;
  margin-top: 2px;
}

.wind-star {
  cursor: pointer;
  user-select: none;
  transition: transform .1s;
}

.wind-star:hover {
  transform: scale(1.15);
}

/* ── History ────────────────────────────────────────────────── */
.wind-history {
  margin-top: 16px;
  background: var(--c-surface);
  border-radius: var(--r-lg);
  padding: 14px;
}

.wind-history-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-weight: 600;
  font-size: .95rem;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.wind-history-count {
  color: var(--c-muted);
  font-weight: 500;
  font-size: .85rem;
}

.wind-history-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.wind-hist-item {
  padding: 8px 10px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm, 6px);
  background: var(--c-bg);
}

.wind-hist-row1,
.wind-hist-row2 {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  font-size: .85rem;
}

.wind-hist-row2 {
  margin-top: 4px;
}

.wind-hist-date {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}

.wind-hist-loc {
  color: var(--c-muted);
  font-size: .82rem;
}

.wind-hist-stars {
  color: #f59e0b;
  letter-spacing: 1px;
  font-size: .82rem;
  margin-left: auto;
}

.wind-hist-del {
  border: none;
  background: transparent;
  color: var(--c-muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 2px 6px;
  border-radius: var(--r-sm, 6px);
}

.wind-hist-del:hover {
  color: var(--wind-danger);
  background: color-mix(in srgb, var(--wind-danger) 10%, transparent);
}

.wind-hist-kite {
  font-weight: 600;
  color: var(--c-primary);
}

.wind-hist-wind {
  color: var(--c-muted);
}

.wind-hist-power {
  padding: 1px 7px;
  border-radius: 99px;
  font-size: .75rem;
  font-weight: 600;
}

.wind-hist-power--ok    { background: color-mix(in srgb, var(--wind-good)   18%, transparent); color: var(--wind-good);   }
.wind-hist-power--under { background: color-mix(in srgb, var(--wind-light)  20%, transparent); color: var(--wind-light);  }
.wind-hist-power--over  { background: color-mix(in srgb, var(--wind-strong) 20%, transparent); color: var(--wind-strong); }

.wind-hist-note {
  margin-top: 4px;
  font-size: .85rem;
  color: var(--c-text);
  opacity: .85;
  font-style: italic;
}

.wind-history--empty .wind-history-list {
  display: none;
}
