/*
 * SFIT Resources — frontend stylesheet.
 *
 * Scoped under .sfit-* class names so it never collides with parent theme
 * styles. Uses the System Force IT brand palette:
 *   primary blue  #0072C6
 *   dark navy     #0A2540
 *   light blue    #7DB9E8
 *   light grey    #F5F7FA
 *   body grey     #4A4A4A
 *
 * UK English in all visible strings (handled in templates, not here).
 */

/* ------- Layout container ------- */

.sfit-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
    box-sizing: border-box;
}

/* ------- Archive ------- */

.sfit-resources-archive { background: #ffffff; }

.sfit-resources-hero {
    background: linear-gradient(180deg, #0072C6 0%, #0A2540 100%);
    color: #ffffff;
    padding: 64px 0 80px 0;
}
.sfit-resources-hero h1 { color: #ffffff; font-size: 40px; line-height: 1.15; margin: 0 0 12px 0; }
.sfit-resources-hero p  { color: #ffffff; font-size: 18px; line-height: 1.55; margin: 0; max-width: 760px; opacity: 0.94; }

.sfit-resources-filterbar {
    background: #F5F7FA;
    border-top: 1px solid #e5e7eb;
    border-bottom: 1px solid #e5e7eb;
    padding: 16px 0;
}
.sfit-resources-filterbar form {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    align-items: center;
}
.sfit-resources-filterbar select,
.sfit-resources-filterbar input[type="search"] {
    padding: 8px 12px;
    border: 1px solid #cdd5dd;
    border-radius: 4px;
    background: #ffffff;
    font-size: 14px;
    min-width: 200px;
}
.sfit-resources-filterbar input[type="search"] { min-width: 280px; flex: 1; }
.sfit-resources-filterbar button {
    background: #0072C6;
    color: #ffffff;
    border: none;
    border-radius: 4px;
    padding: 8px 18px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
}
.sfit-resources-filterbar button:hover { background: #005a9e; }
.sfit-resources-filterbar a.sfit-clear {
    color: #4A4A4A;
    text-decoration: underline;
    font-size: 14px;
}

/* ------- Featured card ------- */

.sfit-resources-featured {
    margin: 40px 0;
    background: #F5F7FA;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 0;
    align-items: stretch;
}
.sfit-resources-featured .sfit-featured-image { padding: 24px; }
.sfit-resources-featured .sfit-featured-image img { width: 100%; height: auto; border: 1px solid #cdd5dd; border-radius: 4px; }
.sfit-resources-featured .sfit-featured-body { padding: 32px 32px 32px 0; }
.sfit-resources-featured h2 { color: #0A2540; font-size: 28px; margin: 8px 0 12px 0; }
.sfit-resources-featured p  { color: #4A4A4A; font-size: 16px; line-height: 1.6; margin: 0 0 16px 0; }
@media (max-width: 768px) {
    .sfit-resources-featured { grid-template-columns: 1fr; }
    .sfit-resources-featured .sfit-featured-body { padding: 0 24px 24px 24px; }
}

/* ------- Resource grid + cards ------- */

.sfit-resources-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    padding: 32px 0 64px 0;
}
@media (max-width: 1024px) { .sfit-resources-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 640px)  { .sfit-resources-grid { grid-template-columns: 1fr; } }

.sfit-resource-card {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.sfit-resource-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(10, 37, 64, 0.08); }
.sfit-resource-card a { text-decoration: none; color: inherit; display: block; }
.sfit-resource-card-image { background: #F5F7FA; padding: 24px; border-bottom: 1px solid #e5e7eb; }
.sfit-resource-card-image img { width: 100%; height: auto; display: block; border: 1px solid #cdd5dd; border-radius: 4px; }
.sfit-resource-card-body { padding: 20px 22px 22px 22px; }
.sfit-resource-card-date { color: #6b7280; font-size: 13px; margin: 0 0 6px 0; }
.sfit-resource-card-title { color: #0A2540; font-size: 18px; line-height: 1.35; margin: 8px 0 10px 0; }
.sfit-resource-card-summary { color: #4A4A4A; font-size: 14px; line-height: 1.55; margin: 0 0 16px 0; }
.sfit-resource-card-readmore { color: #0072C6; font-weight: 600; font-size: 14px; }

.sfit-resource-badge {
    display: inline-block;
    background: #0072C6;
    color: #ffffff;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 4px 10px;
    border-radius: 3px;
}

/* ------- Single resource ------- */

.sfit-resource-single { background: #ffffff; padding: 48px 0; }
.sfit-resource-single .sfit-breadcrumbs { font-size: 13px; color: #6b7280; margin: 0 0 24px 0; }
.sfit-resource-single .sfit-breadcrumbs a { color: #0072C6; text-decoration: none; }
.sfit-resource-single .sfit-breadcrumbs a:hover { text-decoration: underline; }
.sfit-resource-single .sfit-breadcrumbs span.sep { margin: 0 6px; color: #9ca3af; }

.sfit-resource-single .sfit-resource-layout {
    display: grid;
    grid-template-columns: minmax(0, 60%) minmax(0, 38%);
    gap: 48px;
    align-items: start;
}
@media (max-width: 900px) { .sfit-resource-single .sfit-resource-layout { grid-template-columns: 1fr; } }

.sfit-resource-single h1 { color: #0A2540; font-size: 36px; line-height: 1.2; margin: 16px 0 12px 0; }
.sfit-resource-single .sfit-tag { display: inline-block; margin: 0 6px 6px 0; padding: 3px 10px; border-radius: 3px; background: #F5F7FA; color: #0A2540; font-size: 12px; }
.sfit-resource-single .sfit-meta { color: #6b7280; font-size: 14px; margin: 8px 0 24px 0; }
.sfit-resource-single .sfit-resource-lede { font-size: 18px; line-height: 1.6; color: #0A2540; margin: 0 0 24px 0; }
.sfit-resource-single h2 { color: #0072C6; font-size: 22px; margin: 32px 0 12px 0; }
.sfit-resource-single ul.sfit-takeaways { padding-left: 22px; margin: 0 0 24px 0; }
.sfit-resource-single ul.sfit-takeaways li { color: #4A4A4A; font-size: 16px; line-height: 1.65; margin: 6px 0; }
.sfit-resource-single .sfit-resource-content { color: #4A4A4A; font-size: 16px; line-height: 1.7; }
.sfit-resource-single .sfit-resource-content p { margin: 0 0 16px 0; }

.sfit-about-sfit {
    margin-top: 48px;
    padding: 24px;
    background: #F5F7FA;
    border-left: 4px solid #0072C6;
    color: #4A4A4A;
    font-size: 14px;
    line-height: 1.6;
}
.sfit-about-sfit strong { color: #0A2540; }

/* Sticky download/form sidebar */
.sfit-resource-sidebar { position: sticky; top: 24px; }
.sfit-resource-sidebar .sfit-cover {
    background: #F5F7FA;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 20px;
    margin: 0 0 16px 0;
    text-align: center;
}
.sfit-resource-sidebar .sfit-cover img { max-width: 100%; height: auto; border: 1px solid #cdd5dd; border-radius: 4px; }
.sfit-resource-sidebar .sfit-cta { background: #ffffff; border: 1px solid #e5e7eb; border-radius: 8px; padding: 24px; }
.sfit-resource-sidebar .sfit-cta h3 { color: #0A2540; font-size: 18px; margin: 0 0 12px 0; }
.sfit-resource-sidebar .sfit-cta p  { color: #4A4A4A; font-size: 14px; line-height: 1.55; margin: 0 0 16px 0; }

.sfit-button {
    display: inline-block;
    background: #0072C6;
    color: #ffffff !important;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    padding: 12px 24px;
    border-radius: 4px;
    border: none;
    cursor: pointer;
    transition: background 0.15s ease;
}
.sfit-button:hover { background: #005a9e; color: #ffffff !important; }
.sfit-button-block { display: block; width: 100%; text-align: center; }

.sfit-related h3 { color: #0A2540; font-size: 16px; margin: 16px 0 12px 0; }
.sfit-related ul { list-style: none; padding: 0; margin: 0; }
.sfit-related ul li { margin: 0 0 10px 0; padding: 0 0 10px 0; border-bottom: 1px solid #e5e7eb; font-size: 14px; line-height: 1.45; }
.sfit-related ul li:last-child { border-bottom: none; }
.sfit-related ul li a { color: #0072C6; text-decoration: none; }
.sfit-related ul li a:hover { text-decoration: underline; }

/* ------- Resource download landing page ------- */

.sfit-download-page { background: #F5F7FA; padding: 64px 0; min-height: 60vh; }
.sfit-download-page .sfit-thanks-card {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 48px;
    max-width: 720px;
    margin: 0 auto;
    text-align: center;
}
.sfit-download-page h1 { color: #0A2540; font-size: 32px; margin: 0 0 12px 0; }
.sfit-download-page .sfit-resource-title { color: #0072C6; font-weight: 600; font-size: 18px; margin: 0 0 24px 0; }
.sfit-download-page p { color: #4A4A4A; font-size: 16px; line-height: 1.6; margin: 0 0 16px 0; }


