/* ==========================================================================
   Hautahaku WordPress Plugin — Styles v1.3
   Kaikki säännöt scoped .hh-widget sisälle teeman ylikirjoitusten estämiseksi
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600&family=Source+Sans+3:wght@300;400;500&display=swap');

/* ── CSS custom properties ── */
.hh-widget {
  /* Humat brand palette */
  --hhc-navy:     #193652;   /* primary dark navy */
  --hhc-navy-h:   #0f2438;   /* hover darker */
  --hhc-peach:    #D9AE94;   /* accent peach */
  --hhc-peach-h:  #c99a7e;   /* peach hover */
  --hhc-cream:    #FCFBFA;   /* light cream */
  /* Neutrals */
  --hhc-ink:      #393e41;   /* body text */
  --hhc-stone:    #4a5568;
  --hhc-ash:      #6b7280;
  --hhc-mist:     #d1d5db;
  --hhc-white:    #ffffff;
  --hhc-paper:    #f9fafb;
  --hhc-sep:      #e5e7eb;
  /* Moss kept for subtle elements */
  --hhc-moss:     #193652;   /* reuse navy as primary action */
  --hhc-moss-h:   #0f2438;
  --hhc-gold:     #8a6a2a;
  --hhc-warn-bg:  #fdf8ee;
  --hhc-warn-bd:  #e8d89a;
}

/* ── Root reset ── */
.hh-widget {
  all: initial !important;
  display: block !important;
  box-sizing: border-box !important;
  font-family: 'Source Sans 3', Georgia, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
  color: var(--hhc-ink) !important;
  max-width: 700px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 32px 0 48px !important;
  -webkit-font-smoothing: antialiased !important;
}

.hh-widget *, .hh-widget *::before, .hh-widget *::after {
  box-sizing: border-box !important;
}

/* ── Header ── */
.hh-widget .hh-widget__header {
  margin-bottom: 24px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid var(--hhc-mist) !important;
}
.hh-widget .hh-widget__title {
  display: block !important;
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: clamp(19px, 3vw, 26px) !important;
  font-weight: 600 !important;
  color: var(--hhc-ink) !important;
  line-height: 1.25 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.hh-widget .hh-widget__subtitle {
  display: block !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  color: var(--hhc-stone) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Fields row ── */
.hh-widget .hh-widget__fields {
  display: flex !important;
  gap: 10px !important;
  align-items: flex-end !important;
  flex-wrap: wrap !important;
  margin-bottom: 8px !important;
}
.hh-widget .hh-widget__field {
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
}
.hh-widget .hh-widget__field--name {
  flex: 1 1 240px !important;
  min-width: 0 !important;
}
.hh-widget .hh-widget__field--year {
  flex: 0 0 auto !important;
}
.hh-widget .hh-widget__label {
  display: block !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--hhc-ash) !important;
  margin: 0 !important;
  padding: 0 !important;
}
.hh-widget .hh-widget__optional {
  font-weight: 300 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-size: 10px !important;
}

/* ── Name input wrapper ── */
.hh-widget .hh-widget__input-wrap {
  display: flex !important;
  align-items: center !important;
  background: var(--hhc-white) !important;
  border: 1.5px solid var(--hhc-mist) !important;
  border-radius: 4px !important;
  transition: border-color .2s, box-shadow .2s !important;
  overflow: hidden !important;
}
.hh-widget .hh-widget__input-wrap:focus-within {
  border-color: var(--hhc-moss) !important;
  box-shadow: 0 0 0 3px rgba(45,74,46,.08) !important;
}

/* ── Inputs ── */
.hh-widget .hh-widget__input {
  display: block !important;
  width: 100% !important;
  padding: 13px 16px !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  color: var(--hhc-ink) !important;
  background: transparent !important;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  margin: 0 !important;
  min-width: 0 !important;
}
.hh-widget .hh-widget__input::placeholder {
  color: var(--hhc-mist) !important;
  opacity: 1 !important;
}
.hh-widget .hh-widget__input--year {
  width: 100px !important;
  border: 1.5px solid var(--hhc-mist) !important;
  border-radius: 4px !important;
  padding: 13px 12px !important;
  background: var(--hhc-white) !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.hh-widget .hh-widget__input--year:focus {
  border-color: var(--hhc-moss) !important;
  box-shadow: 0 0 0 3px rgba(45,74,46,.08) !important;
  outline: none !important;
}
.hh-widget .hh-widget__input--year::-webkit-inner-spin-button,
.hh-widget .hh-widget__input--year::-webkit-outer-spin-button { -webkit-appearance: none !important; }
.hh-widget .hh-widget__input--year { -moz-appearance: textfield !important; }

/* ── Clear button ── */
.hh-widget .hh-widget__clear {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 32px !important;
  height: 32px !important;
  margin-right: 4px !important;
  background: none !important;
  border: none !important;
  border-radius: 50% !important;
  color: var(--hhc-ash) !important;
  cursor: pointer !important;
  padding: 0 !important;
  transition: background .15s, color .15s !important;
  box-shadow: none !important;
  outline: none !important;
}
.hh-widget .hh-widget__clear:hover {
  background: var(--hhc-paper) !important;
  color: var(--hhc-stone) !important;
}

/* ── Search button ── */
.hh-widget .hh-widget__btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 13px 22px !important;
  background: var(--hhc-navy) !important;
  color: var(--hhc-cream) !important;
  border: none !important;
  border-radius: 4px !important;
  cursor: pointer !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  transition: background .2s !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  box-shadow: none !important;
  height: auto !important;
  line-height: 1 !important;
  margin: 0 !important;
}
.hh-widget .hh-widget__btn:hover:not(:disabled) { background: var(--hhc-navy-h) !important; }
.hh-widget .hh-widget__btn:disabled { background: var(--hhc-ash) !important; cursor: not-allowed !important; }

/* ── Hint ── */
.hh-widget .hh-widget__hint {
  display: block !important;
  font-size: 12px !important;
  color: var(--hhc-ash) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Results ── */
.hh-widget .hh-widget__results { margin-top: 26px !important; }

/* ── Status / loading ── */
.hh-widget .hh-status {
  display: block !important;
  text-align: center !important;
  padding: 18px !important;
  color: var(--hhc-ash) !important;
  font-size: 14px !important;
  font-style: italic !important;
  margin: 0 !important;
}
.hh-widget .hh-spinner {
  display: inline-block !important;
  width: 15px !important; height: 15px !important;
  border: 2px solid var(--hhc-mist) !important;
  border-top-color: var(--hhc-moss) !important;
  border-radius: 50% !important;
  animation: hh-spin .7s linear infinite !important;
  vertical-align: middle !important;
  margin-right: 6px !important;
}
@keyframes hh-spin { to { transform: rotate(360deg); } }

/* ── Section ── */
.hh-widget .hh-section {
  margin-bottom: 20px !important;
  animation: hh-fadein .3s ease both !important;
}
@keyframes hh-fadein {
  from { opacity: 0; transform: translateY(7px); }
  to   { opacity: 1; transform: none; }
}
.hh-widget .hh-section-head {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding-bottom: 8px !important;
  border-bottom: 1px solid var(--hhc-mist) !important;
  margin-bottom: 10px !important;
  flex-wrap: wrap !important;
}
.hh-widget .hh-source-name {
  font-family: Georgia, 'Playfair Display', serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--hhc-ink) !important;
}
.hh-widget .hh-source-count {
  font-size: 12px !important;
  color: var(--hhc-ash) !important;
  margin-left: auto !important;
}
.hh-widget .hh-source-link {
  display: inline-block !important;
  font-size: 11px !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--hhc-navy) !important;
  text-decoration: none !important;
  border: 1px solid var(--hhc-navy) !important;
  padding: 6px 14px !important;
  border-radius: 4px !important;
  transition: all .15s !important;
  white-space: nowrap !important;
  background: transparent !important;
}
.hh-widget .hh-source-link:hover {
  background: var(--hhc-navy) !important;
  color: var(--hhc-cream) !important;
}

/* ── Grave card ── */
.hh-widget .hh-grave {
  display: flex !important;
  justify-content: space-between !important;
  align-items: flex-start !important;
  gap: 14px !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--hhc-sep) !important;
  margin: 0 !important;
}
.hh-widget .hh-grave:last-child { border-bottom: none !important; }
.hh-widget .hh-grave-info { flex: 1 !important; min-width: 0 !important; }
.hh-widget .hh-grave-name {
  display: block !important;
  font-family: Georgia, 'Playfair Display', serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--hhc-ink) !important;
  margin-bottom: 3px !important;
  line-height: 1.3 !important;
}
.hh-widget .hh-grave-dates {
  display: block !important;
  font-size: 12px !important;
  color: var(--hhc-stone) !important;
  margin-bottom: 2px !important;
}
.hh-widget .hh-grave-loc {
  display: block !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--hhc-navy) !important;
  margin: 5px 0 0 !important;
  font-style: normal !important;
  padding: 0 !important;
  line-height: 1.4 !important;
}
.hh-widget .hh-grave-id {
  display: block !important;
  font-family: monospace !important;
  font-size: 11px !important;
  color: var(--hhc-ash) !important;
  letter-spacing: 0.03em !important;
  padding: 0 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}
.hh-widget .hh-grave-meta {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}
.hh-widget .hh-grave-actions {
  display: flex !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
  align-items: flex-start !important;
  flex-wrap: wrap !important;
}
.hh-widget .hh-grave-btn {
  display: inline-block !important;
  padding: 6px 12px !important;
  border: 1px solid var(--hhc-navy) !important;
  color: var(--hhc-navy) !important;
  text-decoration: none !important;
  font-size: 11px !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-weight: 500 !important;
  letter-spacing: .05em !important;
  border-radius: 2px !important;
  transition: all .15s !important;
  white-space: nowrap !important;
  background: transparent !important;
  box-shadow: none !important;
  cursor: pointer !important;
  line-height: 1.4 !important;
}
.hh-widget .hh-grave-btn:hover { background: var(--hhc-navy) !important; color: var(--hhc-cream) !important; }
.hh-widget .hh-grave-btn--map { border-color: var(--hhc-ash) !important; color: var(--hhc-ash) !important; }
.hh-widget .hh-grave-btn--map:hover { background: var(--hhc-stone) !important; border-color: var(--hhc-stone) !important; color: #fff !important; }

/* ── Tip / error ── */
.hh-widget .hh-tip {
  display: block !important;
  font-size: 13px !important;
  color: var(--hhc-ash) !important;
  padding: 8px 0 2px !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}
.hh-widget .hh-tip a { color: var(--hhc-navy) !important; text-decoration: underline !important; }
.hh-widget .hh-tip strong { color: var(--hhc-stone) !important; }
.hh-widget .hh-error {
  display: block !important;
  font-size: 13px !important;
  color: #7a2020 !important;
  padding: 6px 0 !important;
  margin: 0 !important;
}

/* ── Divider ── */
.hh-widget .hh-divider {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 18px 0 14px !important;
  color: var(--hhc-ash) !important;
  font-size: 11px !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
}
.hh-widget .hh-divider::before,
.hh-widget .hh-divider::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  background: var(--hhc-mist) !important;
  display: block !important;
}

/* ── Redirect grid ── */
.hh-widget .hh-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 8px !important;
}
.hh-widget .hh-redir {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px 14px !important;
  background: var(--hhc-navy) !important;
  border: 1px solid var(--hhc-navy) !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  color: var(--hhc-cream) !important;
  transition: background .15s, border-color .15s !important;
  min-width: 0 !important;
  overflow: visible !important;
  text-align: center !important;
  min-height: 56px !important;
  box-sizing: border-box !important;
}
.hh-widget .hh-redir:hover {
  background: var(--hhc-navy-h) !important;
  border-color: var(--hhc-navy-h) !important;
}
/* Icon hidden */
.hh-widget .hh-redir-icon { display: none !important; }
.hh-widget .hh-redir-text {
  display: block !important;
  min-width: 0 !important;
  overflow: visible !important;
  width: 100% !important;
}
.hh-widget .hh-redir-label {
  display: block !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--hhc-cream) !important;
  margin: 0 0 3px !important;
  padding: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.hh-widget .hh-redir-sub {
  display: block !important;
  font-family: 'Source Sans 3', sans-serif !important;
  font-size: 11px !important;
  line-height: 1.3 !important;
  color: rgba(252,251,250,0.7) !important;
  margin: 0 !important;
  padding: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* ── Too many results ── */
.hh-widget .hh-toomany {
  display: flex !important;
  gap: 14px !important;
  align-items: flex-start !important;
  background: var(--hhc-warn-bg) !important;
  border: 1px solid var(--hhc-warn-bd) !important;
  border-left: 3px solid var(--hhc-gold) !important;
  border-radius: 3px !important;
  padding: 14px 16px !important;
  margin: 6px 0 4px !important;
}
.hh-widget .hh-toomany-icon {
  color: var(--hhc-gold) !important;
  flex-shrink: 0 !important;
  margin-top: 2px !important;
  display: flex !important;
}
.hh-widget .hh-toomany-text {
  font-size: 13px !important;
  color: var(--hhc-stone) !important;
  line-height: 1.6 !important;
}
.hh-widget .hh-toomany-text strong { color: var(--hhc-ink) !important; }
.hh-widget .hh-toomany-tips {
  margin: 6px 0 8px 16px !important;
  padding: 0 !important;
  color: var(--hhc-stone) !important;
}
.hh-widget .hh-toomany-tips li { margin-bottom: 2px !important; list-style: disc !important; }
.hh-widget .hh-toomany-link {
  display: inline-block !important;
  font-size: 12px !important;
  color: var(--hhc-navy) !important;
  text-decoration: none !important;
  border-bottom: 1px solid currentColor !important;
  line-height: 1.4 !important;
}
.hh-widget .hh-toomany-link:hover { opacity: 0.75 !important; }

.hh-widget .hh-grave-btn--place {
  background: var(--hhc-peach) !important;
  color: var(--hhc-navy) !important;
  border-color: var(--hhc-peach) !important;
}
.hh-widget .hh-grave-btn--place:hover {
  background: var(--hhc-peach-h) !important;
  border-color: var(--hhc-peach-h) !important;
}

/* ── Responsive ── */
@media (max-width: 520px) {
  .hh-widget .hh-widget__fields { flex-direction: column !important; align-items: stretch !important; }
  .hh-widget .hh-widget__btn { width: 100% !important; justify-content: center !important; }
  .hh-widget .hh-grave { flex-direction: column !important; gap: 8px !important; }
  .hh-widget .hh-grid { grid-template-columns: 1fr !important; }
  .hh-widget .hh-source-count { display: none !important; }
  .hh-widget .hh-redir-sub { display: none !important; }
}
