/* Clay Pittsburgh Potters Directory — style.css */

/* ── Wrapper ──────────────────────────────────────────────────────────────── */
.cpd-directory,
.cpd-submit-wrap {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: #1a1a1a;
    max-width: 960px;
    margin: 0 auto;
}

.cpd-directory *,
.cpd-submit-wrap * {
    box-sizing: border-box;
}

/* ── Header ───────────────────────────────────────────────────────────────── */
.cpd-eyebrow {
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: #999;
    margin: 0 0 6px;
}

.cpd-title {
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 28px;
    font-weight: 400;
    margin: 0 0 8px;
    color: #1a1a1a;
}

.cpd-subtitle {
    font-size: 14px;
    color: #666;
    line-height: 1.6;
    max-width: 560px;
    margin: 0 0 24px;
}

/* ── Map ──────────────────────────────────────────────────────────────────── */
.cpd-map-wrap {
    width: 100%;
    max-width: 560px;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid #ccc;
    margin-bottom: 28px;
}

.cpd-map-svg {
    display: block;
    width: 100%;
    height: auto;
}

/* ── Filters ──────────────────────────────────────────────────────────────── */
.cpd-filters {
    margin-bottom: 16px;
}

.cpd-filters input[type="text"] {
    width: 100%;
    padding: 8px 12px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 6px;
    margin-bottom: 10px;
    font-family: inherit;
}

.cpd-filter-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.cpd-filter-row select {
    font-size: 13px;
    padding: 7px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    background: #fff;
    font-family: inherit;
    cursor: pointer;
}

.cpd-gallery-check {
    font-size: 13px;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    white-space: nowrap;
}

/* ── Count ────────────────────────────────────────────────────────────────── */
.cpd-count {
    font-size: 13px;
    color: #888;
    margin: 8px 0 16px;
}

/* ── Card grid ────────────────────────────────────────────────────────────── */
.cpd-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(275px, 1fr));
    gap: 14px;
}

.cpd-no-results {
    color: #888;
    font-size: 14px;
    padding: 2rem 0;
    grid-column: 1 / -1;
}

/* ── Card ─────────────────────────────────────────────────────────────────── */
.cpd-card {
    background: #fff;
    border: 1px solid #e0ddd8;
    border-radius: 10px;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cpd-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
}

.cpd-card-name {
    font-family: Georgia, serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.3;
    color: #1a1a1a;
}

/* Type badges */
.cpd-badge {
    font-size: 11px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 99px;
    white-space: nowrap;
    flex-shrink: 0;
}

.cpd-badge-student    { background: #e6f0fb; color: #1a4971; }
.cpd-badge-home       { background: #e6f5ec; color: #1a5c36; }
.cpd-badge-shared     { background: #fef3e0; color: #7b4209; }
.cpd-badge-teaching   { background: #e6f5ec; color: #1a5c36; }
.cpd-badge-production { background: #fce9e9; color: #8a1c1c; }

/* Description */
.cpd-card-desc {
    font-size: 13px;
    color: #555;
    line-height: 1.5;
    margin: 0;
}

/* Specialty tags */
.cpd-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.cpd-tag {
    font-size: 11px;
    background: #f2efea;
    color: #666;
    padding: 2px 8px;
    border-radius: 99px;
    border: 1px solid #ddd;
}

/* Meta row */
.cpd-card-meta {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6px;
    font-size: 12px;
}

.cpd-meta-label {
    color: #999;
    margin-bottom: 2px;
}

.cpd-meta-value {
    font-weight: 600;
    color: #333;
}

/* Status badges */
.cpd-status-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cpd-sbadge {
    font-size: 11px;
    font-weight: 600;
    padding: 3px 8px;
    border-radius: 99px;
}

.cpd-sbadge-open    { background: #e6f5ec; color: #1a5c36; }
.cpd-sbadge-appt    { background: #fef3e0; color: #7b4209; }
.cpd-sbadge-private { background: #f2efea; color: #888; }
.cpd-sbadge-classes { background: #e6f0fb; color: #1a4971; }
.cpd-sbadge-gallery { background: #f2efea; color: #666; border: 1px solid #ddd; }

/* Links */
.cpd-card-links {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    border-top: 1px solid #eee;
    padding-top: 10px;
}

.cpd-card-links a {
    font-size: 11px;
    font-weight: 600;
    color: #555;
    padding: 3px 9px;
    border: 1px solid #ccc;
    border-radius: 6px;
    text-decoration: none;
    transition: background 0.1s;
}

.cpd-card-links a:hover {
    background: #f2efea;
    color: #333;
}

/* ── Submission form ──────────────────────────────────────────────────────── */
.cpd-form-note {
    font-size: 13px;
    color: #666;
    line-height: 1.5;
    margin-bottom: 20px;
    padding: 12px 16px;
    background: #f8f6f2;
    border-left: 3px solid #c0392b;
    border-radius: 0 6px 6px 0;
}

.cpd-form {
    width: 100%;
}

.cpd-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-bottom: 20px;
}

.cpd-field {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.cpd-field label {
    font-size: 12px;
    font-weight: 600;
    color: #555;
}

.cpd-field input[type="text"],
.cpd-field input[type="email"],
.cpd-field input[type="url"],
.cpd-field select,
.cpd-field textarea {
    font-size: 13px;
    padding: 8px 10px;
    border: 1px solid #ccc;
    border-radius: 6px;
    background: #fff;
    font-family: inherit;
    width: 100%;
}

.cpd-field textarea {
    resize: vertical;
}

.cpd-field-full {
    grid-column: 1 / -1;
}

.cpd-field-checks {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    gap: 8px;
}

.cpd-field-checks label {
    font-weight: normal;
    display: flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    font-size: 13px;
}

.cpd-checkboxes {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 4px;
}

.cpd-checkboxes label {
    font-weight: normal !important;
    display: flex;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    font-size: 13px;
    color: #1a1a1a;
}

.cpd-qualifier {
    background: #f8f6f2;
    border: 1px solid #ddd;
    border-radius: 8px;
    padding: 14px;
}

.cpd-qualifier label {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    cursor: pointer;
    font-size: 13px;
    line-height: 1.5;
    font-weight: normal !important;
    color: #1a1a1a;
}

.cpd-qualifier input {
    margin-top: 2px;
    flex-shrink: 0;
}

.cpd-submit-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 8px;
}

.cpd-btn-submit {
    background: #2a5298;
    color: #fff;
    border: none;
    padding: 10px 20px;
    font-size: 14px;
    font-weight: 600;
    border-radius: 6px;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s;
}

.cpd-btn-submit:hover {
    background: #1e3d7a;
}

.cpd-submit-note {
    font-size: 12px;
    color: #999;
}

/* ── Messages ─────────────────────────────────────────────────────────────── */
.cpd-success {
    background: #e6f5ec;
    border: 1px solid #a8d5b5;
    color: #1a5c36;
    padding: 16px 20px;
    border-radius: 8px;
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 20px;
}

.cpd-error {
    background: #fce9e9;
    border: 1px solid #e8a0a0;
    color: #8a1c1c;
    padding: 16px 20px;
    border-radius: 8px;
    font-size: 14px;
    margin-bottom: 20px;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
    .cpd-form-grid {
        grid-template-columns: 1fr;
    }

    .cpd-card-meta {
        grid-template-columns: 1fr 1fr;
    }

    .cpd-field-full {
        grid-column: 1;
    }
}
