/**
 * Site pages v2 — SaaS redesign in CollegeVaani brand palette.
 * Loads AFTER course-pages-v2.css (shared --cp-* tokens + cp2-* components).
 * Namespaces: .sc2- scholarships, .bg2- blog, .fq2- faq, .ab2- about,
 * .ct2- contact, .wl2- wishlist, .cm2- compare, .pd2- predictor.
 */

/* ============ Shared small bits ============ */
.sp2-hero { padding: 36px 0 84px; }
.sp2-main { padding: 26px 0 48px; }
.sp2-float { margin-top: -46px; position: relative; z-index: 5; }
.sp2-count { font-size: 13.5px; color: var(--cp-muted); }
.sp2-count strong { color: var(--cp-ink); font-weight: 700; }
.sp2-pagination { margin-top: 26px; display: flex; justify-content: center; }
.sp2-pagination .pagination { gap: 6px; flex-wrap: wrap; }
.sp2-pagination .page-link {
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius-sm) !important;
    color: var(--cp-slate);
    font-weight: 600;
    font-size: 13.5px;
}
.sp2-pagination .page-item.active .page-link { background: var(--cp-primary); border-color: var(--cp-primary); color: #fff; }
.sp2-empty {
    background: var(--cp-white);
    border: 1px dashed var(--cp-border);
    border-radius: var(--cp-radius);
    text-align: center;
    padding: 56px 24px;
}
.sp2-empty__icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: var(--cp-primary-bg);
    color: var(--cp-primary);
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
}
.sp2-empty h4 { font-size: 1.1rem; font-weight: 800; color: var(--cp-ink); margin-bottom: 6px; }
.sp2-empty p { font-size: 14px; color: var(--cp-muted); margin-bottom: 18px; }
.sp2-select {
    border: 1px solid var(--cp-border);
    background: var(--cp-white);
    color: var(--cp-slate);
    font-family: var(--cp-font);
    font-size: 13px;
    font-weight: 600;
    padding: 8px 30px 8px 14px;
    border-radius: var(--cp-pill);
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%235b6470' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
}
.sp2-select:hover, .sp2-select:focus { border-color: var(--cp-primary-light); outline: none; }
.sp2-search {
    display: flex;
    align-items: center;
    background: #fff;
    border-radius: var(--cp-pill);
    padding: 6px 6px 6px 20px;
    max-width: 540px;
    box-shadow: 0 12px 32px rgba(10, 22, 50, 0.28);
}
.sp2-search i { color: var(--cp-muted); font-size: 15px; margin-right: 10px; }
.sp2-search input {
    flex: 1;
    border: 0;
    outline: 0;
    font-family: var(--cp-font);
    font-size: 15px;
    color: var(--cp-ink);
    background: transparent;
    min-width: 0;
}
.sp2-search input::placeholder { color: #93a0b4; }
.sp2-search button {
    border: 0;
    background: var(--cp-amber);
    color: #3c2705;
    font-family: var(--cp-font);
    font-weight: 700;
    font-size: 14px;
    padding: 11px 24px;
    border-radius: var(--cp-pill);
    cursor: pointer;
    white-space: nowrap;
}
.sp2-search button:hover { background: #fbbf3b; }
.sp2-sidecard {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    padding: 18px;
    margin-bottom: 18px;
}
.sp2-sidecard__title { font-size: 15px; font-weight: 800; color: var(--cp-ink); margin: 0 0 12px; }
.sp2-sidecard__title i { color: var(--cp-amber); margin-right: 7px; }
.sp2-ctacard {
    background: linear-gradient(150deg, var(--cp-primary-dark), var(--cp-primary) 75%);
    border-radius: var(--cp-radius);
    padding: 24px 22px;
    color: #fff;
    position: relative;
    overflow: hidden;
    margin-bottom: 18px;
}
.sp2-ctacard::before {
    content: '';
    position: absolute;
    top: -55px;
    right: -55px;
    width: 150px;
    height: 150px;
    border-radius: 50%;
    background: rgba(245, 158, 11, 0.16);
}
.sp2-ctacard h3 { font-size: 16px; font-weight: 800; color: #fff; margin: 0 0 8px; position: relative; }
.sp2-ctacard p { font-size: 13px; line-height: 1.6; color: rgba(255, 255, 255, 0.85); margin: 0 0 14px; position: relative; }
.sp2-ctacard .cp2-btn { position: relative; width: 100%; }

/* ============ SCHOLARSHIPS (.sc2-) ============ */
.sc2-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 18px;
}
.sc2-toolbar form { display: flex; gap: 9px; flex-wrap: wrap; }
.sc2-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.sc2-card {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    padding: 17px 18px;
    display: flex;
    flex-direction: column;
    transition: all 0.22s var(--cp-ease);
}
.sc2-card:hover { border-color: rgba(38, 71, 142, 0.35); box-shadow: var(--cp-shadow-hover); transform: translateY(-2px); }
.sc2-card--featured { border-color: rgba(245, 158, 11, 0.55); }
.sc2-card__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.sc2-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: var(--cp-pill);
    white-space: nowrap;
}
.sc2-tag--type { background: var(--cp-primary-bg); color: var(--cp-primary); }
.sc2-tag--featured { background: var(--cp-amber-bg); color: var(--cp-amber-dark); }
.sc2-card__name { font-size: 15px; font-weight: 800; letter-spacing: -0.01em; line-height: 1.35; margin: 0 0 4px; }
.sc2-card__name a { color: var(--cp-ink); text-decoration: none; }
.sc2-card__name a:hover { color: var(--cp-primary); }
.sc2-card__provider { font-size: 12.5px; font-weight: 600; color: var(--cp-muted); margin: 0 0 8px; }
.sc2-card__provider i { font-size: 11px; margin-right: 5px; color: var(--cp-primary-light); }
.sc2-card__desc { font-size: 13px; line-height: 1.6; color: var(--cp-muted); margin: 0; }
.sc2-card__foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 13px;
    padding-top: 12px;
    border-top: 1px solid var(--cp-snow);
}
.sc2-card__chips { display: flex; flex-wrap: wrap; gap: 6px; }
.sc2-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11.5px;
    font-weight: 700;
    padding: 4px 11px;
    border-radius: var(--cp-pill);
}
.sc2-chip--amount { background: var(--cp-emerald-bg); color: var(--cp-emerald); }
.sc2-chip--deadline { background: var(--cp-amber-bg); color: var(--cp-amber-dark); }
.sc2-chip--expired { background: var(--cp-coral-bg); color: var(--cp-coral); }
.sc2-tips { font-size: 13px; color: var(--cp-slate); line-height: 1.7; padding-left: 18px; margin: 0; }
.sc2-tips li { margin-bottom: 7px; }
.sc2-feat-item { display: block; text-decoration: none; padding: 9px 2px; border-bottom: 1px solid var(--cp-snow); }
.sc2-feat-item:last-child { border-bottom: 0; }
.sc2-feat-item strong { display: block; font-size: 13px; font-weight: 700; color: var(--cp-ink); line-height: 1.35; }
.sc2-feat-item span { font-size: 12px; color: var(--cp-muted); }
.sc2-feat-item:hover strong { color: var(--cp-primary); }

/* ============ BLOG (.bg2-) ============ */
.bg2-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.bg2-card {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: all 0.22s var(--cp-ease);
}
.bg2-card:hover { border-color: rgba(38, 71, 142, 0.35); box-shadow: var(--cp-shadow-hover); transform: translateY(-2px); }
.bg2-card__img { position: relative; aspect-ratio: 16/9; background: var(--cp-snow); overflow: hidden; }
.bg2-card__img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.bg2-card__cat {
    position: absolute;
    top: 10px;
    left: 10px;
    background: rgba(255, 255, 255, 0.94);
    color: var(--cp-primary);
    font-size: 11px;
    font-weight: 800;
    padding: 4px 11px;
    border-radius: var(--cp-pill);
}
.bg2-card__body { padding: 15px 17px 17px; display: flex; flex-direction: column; flex: 1; }
.bg2-card__meta { display: flex; gap: 14px; font-size: 12px; font-weight: 600; color: var(--cp-muted); margin-bottom: 7px; }
.bg2-card__meta i { font-size: 11px; margin-right: 4px; color: var(--cp-primary-light); }
.bg2-card__title { font-size: 14.5px; font-weight: 800; line-height: 1.4; letter-spacing: -0.01em; margin: 0 0 6px; }
.bg2-card__title a {
    color: var(--cp-ink);
    text-decoration: none;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.bg2-card__title a:hover { color: var(--cp-primary); }
.bg2-card__excerpt {
    font-size: 13px;
    line-height: 1.6;
    color: var(--cp-muted);
    margin: 0 0 12px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.bg2-card__read {
    margin-top: auto;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    font-size: 13px;
    font-weight: 800;
    color: var(--cp-primary);
    text-decoration: none;
}
.bg2-card__read:hover { color: var(--cp-primary-dark); }

/* ============ FAQ (.fq2-) ============ */
.fq2-area { background: var(--cp-bg); padding: 0 0 56px; }
.fq2-nav {
    position: sticky;
    top: 70px;
    z-index: 20;
    background: rgba(244, 246, 250, 0.92);
    backdrop-filter: blur(8px);
    padding: 11px 0;
    border-bottom: 1px solid var(--cp-border);
    margin-bottom: 26px;
}
.fq2-nav__row { display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; }
.fq2-nav__row::-webkit-scrollbar { display: none; }
.fq2-nav__link {
    flex: 0 0 auto;
    border: 1px solid var(--cp-border);
    background: var(--cp-white);
    color: var(--cp-slate);
    font-size: 12.5px;
    font-weight: 700;
    padding: 7px 15px;
    border-radius: var(--cp-pill);
    text-decoration: none;
    white-space: nowrap;
    transition: all 0.18s var(--cp-ease);
}
.fq2-nav__link:hover { border-color: var(--cp-primary); color: var(--cp-primary); background: var(--cp-primary-bg); }
.fq2-area .faq-section { scroll-margin-top: 130px; margin-bottom: 34px; }
.fq2-area .faq-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--cp-ink);
    letter-spacing: -0.015em;
    border: 0;
    padding: 0;
    margin-bottom: 14px;
}
.fq2-area .faq-section-title i {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: var(--cp-primary-bg);
    color: var(--cp-primary) !important;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.fq2-area .accordion-item {
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius-sm) !important;
    margin-bottom: 10px;
    overflow: hidden;
    background: var(--cp-white);
}
.fq2-area .accordion-button {
    font-family: var(--cp-font);
    font-size: 14.5px;
    font-weight: 700;
    color: var(--cp-ink);
    background: var(--cp-white);
    padding: 15px 18px;
    box-shadow: none;
}
.fq2-area .accordion-button:not(.collapsed) { color: var(--cp-primary); background: var(--cp-primary-bg); }
.fq2-area .accordion-button:focus { box-shadow: none; }
.fq2-area .accordion-body { font-size: 14px; color: var(--cp-slate); line-height: 1.7; }
.fq2-area .accordion-body ul, .fq2-area .accordion-body ol { margin-bottom: 0; padding-left: 20px; }
.fq2-area .accordion-body li { margin-bottom: 8px; }
.fq2-area .accordion-body h6 { font-weight: 800; color: var(--cp-ink); font-size: 13.5px; margin: 12px 0 6px; }
.fq2-cta {
    background: linear-gradient(150deg, var(--cp-primary-dark), var(--cp-primary) 75%);
    border-radius: var(--cp-radius);
    padding: 38px 30px;
    text-align: center;
    color: #fff;
    position: relative;
    overflow: hidden;
}
.fq2-cta::before {
    content: '';
    position: absolute;
    top: -65px;
    right: -65px;
    width: 190px;
    height: 190px;
    border-radius: 50%;
    background: rgba(245, 158, 11, 0.16);
}
.fq2-cta h3 { color: #fff; font-size: 1.3rem; font-weight: 800; margin-bottom: 10px; position: relative; }
.fq2-cta p { color: rgba(255, 255, 255, 0.85); font-size: 14px; max-width: 560px; margin: 0 auto 20px; position: relative; }
.fq2-cta__btns { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; position: relative; }

/* ============ ABOUT (.ab2-) ============ */
.ab2-body { padding: 36px 0 10px; }
.ab2-panel {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    padding: 30px;
}
.ab2-img { border-radius: var(--cp-radius); overflow: hidden; border: 1px solid var(--cp-border); }
.ab2-img img { width: 100%; height: auto; display: block; }
.ab2-heading { font-size: 1.45rem; font-weight: 800; color: var(--cp-ink); letter-spacing: -0.02em; margin: 0 0 14px; }
.ab2-text { font-size: 14.5px; line-height: 1.75; color: var(--cp-slate); }
.ab2-points { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 10px; }
.ab2-points li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 14px;
    font-weight: 600;
    color: var(--cp-ink);
}
.ab2-points li::before {
    content: '\f00c';
    font-family: 'Font Awesome 5 Free';
    font-weight: 900;
    flex: 0 0 22px;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    background: var(--cp-emerald-bg);
    color: var(--cp-emerald);
    font-size: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 1px;
}

/* ============ CONTACT (.ct2-) ============ */
.ct2-info-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}
.ct2-info {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.07);
    padding: 18px;
    display: flex;
    align-items: flex-start;
    gap: 13px;
}
.ct2-info__icon {
    flex: 0 0 42px;
    width: 42px;
    height: 42px;
    border-radius: 11px;
    background: var(--cp-primary-bg);
    color: var(--cp-primary);
    font-size: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.ct2-info h5 { font-size: 13.5px; font-weight: 800; color: var(--cp-ink); margin: 2px 0 3px; }
.ct2-info p { font-size: 12.5px; line-height: 1.55; color: var(--cp-muted); margin: 0; word-break: break-word; }
.ct2-info a { color: var(--cp-primary); font-weight: 700; text-decoration: none; }
.ct2-form-wrap { padding: 30px 0 52px; }
.ct2-form {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    padding: 28px 30px;
}
.ct2-form h2 { font-size: 1.35rem; font-weight: 800; color: var(--cp-ink); letter-spacing: -0.02em; margin: 0 0 6px; }
.ct2-form > p, .ct2-form .ct2-sub { font-size: 13.5px; color: var(--cp-muted); margin: 0 0 20px; line-height: 1.6; }
.ct2-form .form-control {
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius-sm);
    font-family: var(--cp-font);
    font-size: 14px;
    padding: 11px 14px;
    margin-bottom: 14px;
    color: var(--cp-ink);
}
.ct2-form .form-control:focus { border-color: var(--cp-primary); box-shadow: 0 0 0 3px var(--cp-primary-bg); }
.ct2-side {
    background: linear-gradient(150deg, var(--cp-primary-dark), var(--cp-primary) 75%);
    border-radius: var(--cp-radius);
    padding: 30px 26px;
    color: #fff;
    height: 100%;
    position: relative;
    overflow: hidden;
}
.ct2-side::before {
    content: '';
    position: absolute;
    top: -65px;
    right: -65px;
    width: 190px;
    height: 190px;
    border-radius: 50%;
    background: rgba(245, 158, 11, 0.16);
}
.ct2-side h3 { color: #fff; font-size: 1.2rem; font-weight: 800; margin: 0 0 10px; position: relative; }
.ct2-side p { color: rgba(255, 255, 255, 0.85); font-size: 13.5px; line-height: 1.65; position: relative; }
.ct2-side__list { list-style: none; padding: 0; margin: 18px 0 0; display: grid; gap: 12px; position: relative; }
.ct2-side__list li { display: flex; align-items: center; gap: 10px; font-size: 13.5px; font-weight: 700; color: #fff; }
.ct2-side__list li i { color: var(--cp-amber); width: 18px; text-align: center; }

/* ============ WISHLIST (.wl2-) ============ */
.wl2-section-title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.12rem;
    font-weight: 800;
    color: var(--cp-ink);
    letter-spacing: -0.015em;
    margin: 0 0 14px;
}
.wl2-section-title i {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: var(--cp-primary-bg);
    color: var(--cp-primary);
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.wl2-card {
    background: var(--cp-white);
    border: 1px solid var(--cp-border);
    border-radius: var(--cp-radius);
    box-shadow: var(--cp-shadow);
    height: 100%;
    display: flex;
    flex-direction: column;
    transition: all 0.22s var(--cp-ease);
}
.wl2-card:hover { border-color: rgba(38, 71, 142, 0.35); box-shadow: var(--cp-shadow-hover); transform: translateY(-2px); }
.wl2-card__body { display: flex; align-items: flex-start; gap: 12px; padding: 16px 16px 0; flex: 1; }
.wl2-card__logo {
    flex: 0 0 54px;
    width: 54px;
    height: 54px;
    border-radius: 11px;
    border: 1px solid var(--cp-border);
    background: var(--cp-white);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}
.wl2-card__logo img { width: 100%; height: 100%; object-fit: contain; padding: 5px; }
.wl2-card__logo i { font-size: 18px; color: var(--cp-primary); }
.wl2-card__name { font-size: 14px; font-weight: 800; line-height: 1.35; margin: 1px 0 4px; }
.wl2-card__name a { color: var(--cp-ink); text-decoration: none; }
.wl2-card__name a:hover { color: var(--cp-primary); }
.wl2-card__meta { font-size: 12.5px; font-weight: 600; color: var(--cp-muted); margin: 0 0 6px; }
.wl2-card__meta i { font-size: 11px; margin-right: 4px; color: var(--cp-primary-light); }
.wl2-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11.5px;
    font-weight: 700;
    padding: 3px 10px;
    border-radius: var(--cp-pill);
}
.wl2-chip--rating { background: var(--cp-emerald-bg); color: var(--cp-emerald); }
.wl2-chip--fee { background: var(--cp-amber-bg); color: var(--cp-amber-dark); }
.wl2-remove {
    flex: 0 0 auto;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    border: 1px solid var(--cp-border);
    background: var(--cp-white);
    color: var(--cp-muted);
    font-size: 12px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.18s var(--cp-ease);
}
.wl2-remove:hover { border-color: var(--cp-coral); background: var(--cp-coral-bg); color: var(--cp-coral); }
.wl2-card__foot { display: flex; gap: 9px; padding: 13px 16px 16px; }
.wl2-card__foot .cp2-btn { flex: 1; padding: 8px 10px; font-size: 12.5px; }
.wl2-clear {
    border: 1px solid var(--cp-border);
    background: var(--cp-white);
    color: var(--cp-coral);
    font-family: var(--cp-font);
    font-size: 13.5px;
    font-weight: 700;
    padding: 10px 22px;
    border-radius: var(--cp-radius-sm);
    cursor: pointer;
    transition: all 0.18s var(--cp-ease);
}
.wl2-clear:hover { border-color: var(--cp-coral); background: var(--cp-coral-bg); }

/* ============ RESPONSIVE (sc2/bg2) ============ */
@media (max-width: 991px) {
    .bg2-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .sc2-grid { grid-template-columns: 1fr; }
    .ct2-info-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575px) {
    .ct2-info-grid { grid-template-columns: 1fr; }
    .ct2-form { padding: 20px 16px; }
    .ab2-panel { padding: 20px 16px; }
}
@media (max-width: 575px) {
    .sp2-hero { padding: 28px 0 76px; }
    .bg2-grid { grid-template-columns: 1fr; }
    .sc2-toolbar { flex-direction: column; align-items: stretch; }
    .sc2-toolbar form { width: 100%; }
    .sc2-toolbar .sp2-select { flex: 1; }
    .sp2-search { padding: 5px 5px 5px 16px; }
    .sp2-search button { padding: 10px 16px; font-size: 13px; }
}
