/* ── Frontend: School Campuses Manager ───────────────────────────────────── */

/* ── Section wrapper ──────────────────────────────────────────────────────── */
.scm-campuses-section {
    padding: 40px 0;
}
.scm-no-campuses {
    text-align: center;
    color: #666;
    padding: 40px 0;
}

/* ── Grid ─────────────────────────────────────────────────────────────────── */
.scm-campuses-grid {
    display: grid;
    gap: 28px;
}
.scm-cols-1 { grid-template-columns: 1fr; }
.scm-cols-2 { grid-template-columns: repeat(2, 1fr); }
.scm-cols-3 { grid-template-columns: repeat(3, 1fr); }
.scm-cols-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 992px) {
    .scm-cols-3,
    .scm-cols-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .scm-campuses-grid { grid-template-columns: 1fr; }
}

/* ── Campus Card ──────────────────────────────────────────────────────────── */
.scm-campus-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 16px rgba(0,0,0,0.08);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.scm-campus-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(0,0,0,0.14);
}
.scm-card-image {
    aspect-ratio: 16/9;
    overflow: hidden;
}
.scm-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.scm-campus-card:hover .scm-card-image img {
    transform: scale(1.05);
}
.scm-card-body {
    padding: 20px 20px 12px;
    flex: 1;
}
.scm-card-title {
    font-size: 1.15rem;
    margin: 0 0 8px;
    line-height: 1.3;
}
.scm-card-title a {
    color: #1a1a2e;
    text-decoration: none;
}
.scm-card-title a:hover { color: #0056d2; }
.scm-card-location,
.scm-card-phone {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 0.875rem;
    color: #555;
    margin: 4px 0;
}
.scm-card-location .dashicons,
.scm-card-phone .dashicons { font-size: 16px; color: #0056d2; }
.scm-card-phone a { color: inherit; text-decoration: none; }
.scm-card-excerpt {
    font-size: 0.875rem;
    color: #666;
    margin-top: 10px;
    line-height: 1.5;
}
.scm-card-footer {
    padding: 14px 20px 20px;
}
.scm-btn-view-details {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #0056d2;
    color: #fff;
    padding: 9px 20px;
    border-radius: 6px;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.2s ease;
}
.scm-btn-view-details:hover { background: #003f9e; color: #fff; }
.scm-btn-view-details .dashicons { font-size: 16px; }

/* ── Single Campus Page ───────────────────────────────────────────────────── */
.scm-single-campus-main {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 20px 60px;
}

/* Hero */
.scm-hero {
    position: relative;
    margin-bottom: 40px;
}
.scm-hero-image img {
    width: 100%;
    max-height: 420px;
    object-fit: cover;
    border-radius: 12px;
    display: block;
}
.scm-hero-content {
    margin-top: 20px;
}
.scm-campus-title {
    font-size: 2rem;
    margin: 0 0 10px;
    color: #1a1a2e;
}
.scm-badge-location {
    display: inline-block;
    background: #e0eaff;
    color: #0056d2;
    padding: 4px 14px;
    border-radius: 20px;
    font-size: 0.875rem;
    font-weight: 600;
}

/* Layout */
.scm-single-wrap {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: 40px;
    align-items: start;
}
@media (max-width: 768px) {
    .scm-single-wrap { grid-template-columns: 1fr; }
}

/* Sections */
.scm-section {
    margin-bottom: 40px;
}
.scm-section h2 {
    font-size: 1.4rem;
    color: #1a1a2e;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 2px solid #e8f0fe;
}

/* Facilities */
.scm-facilities-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
}
.scm-facility-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f8f9ff;
    border: 1px solid #e0eaff;
    border-radius: 8px;
    padding: 10px 14px;
    font-size: 0.9rem;
    color: #333;
}
.scm-facility-item .dashicons { color: #0056d2; font-size: 18px; }

/* Gallery */
.scm-gallery-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 14px;
}
.scm-gallery-item {
    border-radius: 8px;
    overflow: hidden;
    aspect-ratio: 4/3;
}
.scm-gallery-link img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.3s ease;
}
.scm-gallery-link:hover img { transform: scale(1.08); }

/* Map */
.scm-map-embed iframe {
    width: 100%;
    min-height: 320px;
    border-radius: 10px;
    border: none;
    display: block;
}

/* Contact Card (Sidebar) */
.scm-contact-card {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 20px rgba(0,0,0,0.09);
    padding: 24px;
    margin-bottom: 20px;
}
.scm-contact-card-title {
    font-size: 1.1rem;
    margin: 0 0 18px;
    color: #1a1a2e;
    border-bottom: 2px solid #e8f0fe;
    padding-bottom: 10px;
}
.scm-contact-item {
    display: flex;
    gap: 12px;
    margin-bottom: 16px;
    align-items: flex-start;
}
.scm-contact-item .dashicons {
    color: #0056d2;
    font-size: 20px;
    margin-top: 2px;
    flex-shrink: 0;
}
.scm-contact-item strong {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #888;
    margin-bottom: 3px;
}
.scm-contact-item p {
    margin: 0;
    font-size: 0.9rem;
    color: #333;
    line-height: 1.5;
}
.scm-contact-item a { color: #0056d2; text-decoration: none; }
.scm-contact-item a:hover { text-decoration: underline; }

.scm-btn-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #555;
    font-size: 0.875rem;
    text-decoration: none;
    border: 1px solid #ddd;
    padding: 8px 14px;
    border-radius: 6px;
    transition: background 0.2s, color 0.2s;
}
.scm-btn-back:hover {
    background: #f0f0f0;
    color: #000;
}

