/* ============================================================
   PHAROS — The Coast (gallery)
   ============================================================ */
.coast-controls {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.8rem 1.2rem;
  padding: 1.1rem 1.3rem; margin-bottom: var(--s-4);
  background: var(--glass); border: 1px solid var(--hair); border-radius: var(--r-lg);
  position: sticky; top: calc(var(--nav-h) + 10px); z-index: 40;
  backdrop-filter: blur(12px);
}
.coast-search { display: flex; align-items: center; gap: 0.6rem; flex: 1; min-width: 180px; }
.coast-search input {
  background: var(--deepest); border: 1px solid var(--hair); border-radius: var(--r-pill);
  color: var(--foam); font-family: var(--font-mono); font-size: var(--t-small); padding: 0.55rem 1rem; width: 100%;
}
.coast-search input:focus { outline: none; border-color: var(--signal); }
.coast-search input::placeholder { color: var(--dimmer); }
.chips { display: flex; gap: 0.4rem; flex-wrap: wrap; }
.chip {
  font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--dim); background: var(--deepest); border: 1px solid var(--hair); border-radius: var(--r-pill);
  padding: 0.45rem 0.85rem; cursor: pointer; transition: all var(--fast);
}
.chip:hover { color: var(--foam); border-color: var(--hair-strong); }
.chip.is-on { color: var(--ground); background: var(--light); border-color: var(--light); }
.coast-count { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: 0.1em; color: var(--dim); margin-left: auto; }

.coast-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 1.2rem;
}
.cc {
  background: linear-gradient(to bottom, var(--glass), var(--coast)); border: 1px solid var(--hair);
  border-radius: var(--r-lg); overflow: hidden; cursor: pointer; text-align: left;
  transition: transform var(--med) var(--ease), border-color var(--med), box-shadow var(--med); padding: 0;
}
.cc:hover { transform: translateY(-6px); border-color: var(--light-deep); box-shadow: 0 26px 50px -28px rgba(0,0,0,0.9), 0 0 30px -10px var(--light-glow); }
.cc__art { height: 280px; background: radial-gradient(80% 60% at 50% 100%, var(--glass-2), transparent); }
.cc__art .lh-svg { width: 100%; height: 100%; }
.cc__meta { display: flex; justify-content: space-between; align-items: center; padding: 0.85rem 1rem; border-top: 1px solid var(--hair-soft); }
.cc__id { font-family: var(--font-mono); font-size: var(--t-small); color: var(--foam); }
.cc__tier { font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: 0.1em; text-transform: uppercase; color: var(--light); }

.coast-more { display: flex; justify-content: center; margin-top: var(--s-4); }
.coast-empty { text-align: center; color: var(--dim); padding: var(--s-5) 0; font-family: var(--font-mono); font-size: var(--t-small); }

/* ---- focus modal ---- */
.focus {
  position: fixed; inset: 0; z-index: 200; display: none; place-items: center;
  background: rgba(4,9,17,0.82); backdrop-filter: blur(10px); padding: 2rem;
}
.focus.is-open { display: grid; }
.focus__card {
  width: min(900px, 100%); max-height: 90vh; overflow: auto;
  display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 0;
  background: linear-gradient(150deg, var(--glass), var(--deepest)); border: 1px solid var(--hair-strong);
  border-radius: var(--r-lg); box-shadow: var(--lift-2);
}
.focus__art { background: radial-gradient(70% 50% at 50% 100%, var(--glass-2), var(--deepest)); display: grid; place-items: center; padding: 2rem; }
.focus__art .lh-svg { height: 420px; max-height: 60vh; }
.focus__info { padding: 2rem 2.2rem; display: flex; flex-direction: column; }
.focus__info h3 { font-size: 2.2rem; margin: 0.3rem 0 0.2rem; }
.focus__sub { font-family: var(--font-mono); font-size: var(--t-small); color: var(--light); letter-spacing: 0.1em; }
.focus__traits { margin: 1.6rem 0; border-top: 1px solid var(--hair); }
.focus__row { display: flex; justify-content: space-between; padding: 0.7rem 0; border-bottom: 1px solid var(--hair-soft); font-size: var(--t-small); }
.focus__row span { color: var(--dim); font-family: var(--font-mono); font-size: var(--t-micro); letter-spacing: 0.1em; text-transform: uppercase; }
.focus__row strong { color: var(--foam); font-family: var(--font-display); font-weight: 400; font-size: 1.05rem; }
.focus__nav { display: flex; gap: 0.7rem; margin-top: auto; }
.focus__close { position: absolute; top: 1.4rem; right: 1.6rem; background: none; border: 0; color: var(--foam); font-size: 1.8rem; cursor: pointer; line-height: 1; }
.focus__close:hover { color: var(--light); }
@media (max-width: 680px){ .focus__card{ grid-template-columns: 1fr; } .focus__art{ padding: 1.4rem; } .focus__art .lh-svg{ height: 300px; } }
