/** Locations page */

.locations-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 24px;
}
.location-card {
    background: #fff; border: 1px solid var(--c-border);
    border-radius: var(--radius-lg); padding: 36px;
    box-shadow: var(--shadow-sm); transition: var(--trans);
    display: flex; flex-direction: column; gap: 18px;
}
.location-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--c-gold); }
.location-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.location-card-head h3 { font-family: var(--font-serif); font-size: 1.6rem; color: var(--c-night); }
.location-card-head .state-abbr { font-family: var(--font-serif); font-size: 2rem; color: var(--c-gold); line-height: 1; }
.location-card-meta { color: var(--c-text-muted); font-size: 14px; line-height: 1.7; }
.location-card-meta li { list-style: none; padding: 6px 0; border-bottom: 1px solid var(--c-border); display: flex; justify-content: space-between; }
.location-card-meta li:last-child { border-bottom: none; }
.location-card-meta li strong { color: var(--c-text); font-weight: 600; }

.territories-list {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px;
}
.territories-list .territory-item {
    padding: 12px 16px; background: var(--c-bg-alt);
    border-radius: 8px; font-size: 14px; color: var(--c-text);
}
.territories-list .territory-item strong { color: var(--c-night); display: block; margin-bottom: 4px; }
.territories-list .territory-item small { color: var(--c-text-faint); font-size: 12px; }

.available-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px;
}
.available-item {
    padding: 18px 20px; border-radius: 10px; background: #fff;
    border: 1.5px dashed var(--c-border); transition: var(--trans);
    display: flex; justify-content: space-between; align-items: center;
}
.available-item:hover { border-color: var(--c-gold); border-style: solid; }
.available-item strong { font-weight: 600; color: var(--c-night); }
.available-item small { color: var(--c-gold); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
