/* ============================================================
   Šv. Jokūbo kelias — shared components
   Reused across all page mockups. Square corners, hairline
   rules, monochrome + federation red. Loaded after theme.css.
   ============================================================ */

/* ---- Icon base ---- */
.icon { width: 1.25em; height: 1.25em; display: inline-block;
        vertical-align: -0.18em; flex: none; }

/* ============================================================
   Photo placeholder — elegant monochrome/duotone with a
   descriptive label. Stands in for real photography.
   ============================================================ */
.ph {
  position: relative;
  display: block;
  overflow: hidden;
  background:
    linear-gradient(178deg, rgba(255,255,255,0) 70.6%, rgba(255,255,255,0.16) 71.4%, rgba(255,255,255,0) 72.2%),
    radial-gradient(120% 80% at 50% 8%, rgba(255,255,255,0.10), transparent 55%),
    linear-gradient(178deg, #6f6b66 0%, #57534e 38%, #3a3633 70%, #2a2724 100%);
}
.ph--dusk { background:
    radial-gradient(90% 70% at 72% 14%, rgba(255,255,255,0.16), transparent 50%),
    linear-gradient(176deg, #4a4642 0%, #36322f 46%, #211e1c 100%); }
.ph--forest { background:
    radial-gradient(120% 90% at 30% 100%, rgba(255,255,255,0.05), transparent 55%),
    linear-gradient(180deg, #5d5953 0%, #45413c 40%, #2c2926 100%); }
.ph--interior { background:
    radial-gradient(70% 90% at 50% 0%, rgba(255,255,255,0.22), transparent 60%),
    linear-gradient(180deg, #76716b 0%, #5a5550 55%, #423e3a 100%); }
.ph--field { background:
    linear-gradient(178deg, rgba(255,255,255,0) 64.6%, rgba(255,255,255,0.15) 65.4%, rgba(255,255,255,0) 66.2%),
    radial-gradient(100% 70% at 50% 6%, rgba(255,255,255,0.14), transparent 55%),
    linear-gradient(178deg, #807a72 0%, #635d56 50%, #46413b 100%); }

/* shell watermark */
.ph__shell {
  position: absolute;
  right: -6%; bottom: -10%;
  width: 42%; height: auto;
  color: rgba(255,255,255,0.09);
  z-index: 1;
  pointer-events: none;
}
.ph__cap {
  position: absolute; z-index: 2;
  left: var(--sp-30); bottom: var(--sp-30);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.82);
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
  max-width: 78%;
  line-height: 1.35;
}
.ph__cap::before {
  content: "";
  display: inline-block;
  width: 14px; height: 1px;
  background: var(--red);
  vertical-align: middle;
  margin-right: 8px;
}

/* Aspect helpers */
.ar-16-9 { aspect-ratio: 16 / 9; }
.ar-4-3  { aspect-ratio: 4 / 3; }
.ar-1-1  { aspect-ratio: 1 / 1; }
.ar-3-2  { aspect-ratio: 3 / 2; }
.ar-8-5  { aspect-ratio: 8 / 5; }

/* ============================================================
   Badges — category system (icon + label), states
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--gray-60);
  background: var(--white);
  border: 1px solid var(--rule);
  padding: 0.3rem 0.6rem;
  line-height: 1;
}
.badge .icon { width: 1em; height: 1em; color: var(--gray-30); }

/* Sanctuary marker — the one privileged badge (red) */
.badge--sanctuary {
  color: var(--red);
  border-color: rgba(191,41,57,0.32);
  background: var(--white);
}
.badge--sanctuary .icon { color: var(--red); }

/* Category eyebrow (used on location cards) */
.cat-eyebrow {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--red);
}

/* ============================================================
   Cards
   ============================================================ */

/* — Municipality card — coat-of-arms badge overlapping hero — */
.card-mun {
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 1px solid var(--rule);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur) var(--ease);
}
.card-mun__media { position: relative; overflow: hidden; }
.card-mun__media .ph { transition: transform var(--dur) var(--ease); }
.card-mun__crest {
  position: absolute;
  left: var(--sp-30);
  bottom: calc(-1 * var(--sp-30));
  width: 76px; height: 76px;
  border-radius: 50%;
  background: var(--white);
  border: 3px solid var(--white);
  box-shadow: 0 2px 10px rgba(0,0,0,0.16);
  display: grid; place-items: center;
  overflow: hidden;
  z-index: 2;
}
.card-mun__crest .icon { width: 38px; height: 38px; color: var(--gray-30); }
.card-mun__body {
  padding: calc(var(--sp-30) + var(--sp-30)) var(--sp-40) var(--sp-40);
}
.card-mun__title {
  font-family: var(--font-head); font-weight: 600;
  font-size: var(--text-l); line-height: 1.25; letter-spacing: -0.01em;
  margin: 0 0 var(--sp-20);
}
.card-mun__excerpt { font-size: var(--text-s); color: var(--gray-60); margin: 0; line-height: 1.55; }
.card-mun:hover { border-color: var(--red); }
.card-mun:hover .card-mun__media .ph { transform: scale(1.03); }

/* — News card — editorial, no border, hairline rule under — */
.card-news {
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
}
.card-news__media { overflow: hidden; margin-bottom: var(--sp-30); }
.card-news__media .ph { transition: transform var(--dur) var(--ease); }
.card-news__date {
  font-family: var(--font-body); font-weight: 500;
  font-size: var(--text-xs); letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--gray-30);
  margin-bottom: var(--sp-20);
}
.card-news__title {
  font-family: var(--font-head); font-weight: 600;
  font-size: var(--text-l); line-height: 1.28; letter-spacing: -0.01em;
  margin: 0 0 var(--sp-20);
  transition: color var(--dur) var(--ease);
}
.card-news__excerpt { font-size: var(--text-s); color: var(--gray-60); margin: 0; line-height: 1.55; }
.card-news:hover .card-news__title { color: var(--red); }
.card-news:hover .card-news__media .ph { transform: scale(1.03); }

/* — Sanctuary card — passport-stamp ceremony treatment — */
.card-sanctuary {
  position: relative;
  display: flex; flex-direction: column;
  background: var(--off-white);
  border: 1px solid var(--rule);
  text-decoration: none; color: inherit;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.card-sanctuary__media { position: relative; overflow: hidden; }
.card-sanctuary__no {
  position: absolute; top: var(--sp-30); left: var(--sp-30);
  font-family: var(--font-head); font-weight: 600;
  font-size: var(--text-s);
  color: var(--white);
  background: var(--red);
  width: 2rem; height: 2rem;
  display: grid; place-items: center;
  z-index: 2;
}
.card-sanctuary__body { padding: var(--sp-40); }
.card-sanctuary__region {
  font-size: var(--text-xs); text-transform: uppercase;
  letter-spacing: 0.08em; color: var(--gray-30); font-weight: 600;
  margin-bottom: var(--sp-20);
}
.card-sanctuary__name {
  font-family: var(--font-head); font-weight: 600;
  font-size: var(--text-l); line-height: 1.25; letter-spacing: -0.01em;
  margin: 0;
}
.card-sanctuary__shell {
  position: absolute; right: -10%; top: -14%;
  width: 38%; color: rgba(0,0,0,0.035);
  pointer-events: none;
}
.card-sanctuary:hover { border-color: var(--red); background: var(--white); }

/* ============================================================
   Forms
   ============================================================ */
.field { display: flex; flex-direction: column; gap: var(--sp-20); }
.field label {
  font-family: var(--font-body); font-weight: 600;
  font-size: var(--text-xs); text-transform: uppercase;
  letter-spacing: 0.07em; color: var(--gray-80);
}
.input, .textarea, .select {
  font-family: var(--font-body); font-size: 16px; /* prevents iOS zoom */
  color: var(--black);
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: 0;
  padding: 0.8rem 0.9rem;
  width: 100%;
  transition: border-color var(--dur) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--gray-30); }
.input:hover, .textarea:hover, .select:hover { border-color: var(--gray-30); }
.input:focus-visible, .textarea:focus-visible, .select:focus-visible {
  outline: none; border-color: var(--red);
  box-shadow: inset 0 0 0 1px var(--red);
}
.input:disabled { background: var(--muted); color: var(--gray-30); cursor: not-allowed; }
.field__hint { font-size: var(--text-xs); color: var(--gray-60); }
.field--error .input { border-color: var(--red); }
.field--error .field__hint { color: var(--red); }

/* Search input with leading icon */
.search {
  display: flex; align-items: center; gap: var(--sp-20);
  border: 1px solid var(--black); padding: 0.7rem 0.9rem; background: var(--white);
}
.search .icon { color: var(--gray-60); }
.search input { border: none; outline: none; font-size: 16px; width: 100%;
                font-family: var(--font-body); background: transparent; }
