/* ==========================================================================
   IGNOU Store Theme — Custom CSS (Amazon-Inspired)
   Standalone Theme v2.0
   ========================================================================== */

/* ---- KEYFRAME ANIMATIONS ---- */
@keyframes slideDown { from { transform: translateY(-100%); } to { transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.05); } }
@keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes bounceIn { 0% { transform: scale(.8); opacity: 0; } 60% { transform: scale(1.05); } 100% { transform: scale(1); opacity: 1; } }
@keyframes slideInLeft { from { transform: translateX(-100%); } to { transform: translateX(0); } }
@keyframes cartPop { 0% { transform: scale(1); } 50% { transform: scale(1.3); } 100% { transform: scale(1); } }

/* ---- SPINNER ---- */
.ignou-spinner {
    display: inline-block;
    width: 16px; height: 16px;
    border: 2px solid #ddd;
    border-top-color: var(--ignou-link);
    border-radius: 50%;
    animation: spin .6s linear infinite;
    vertical-align: middle;
    margin-right: 6px;
}

/* ---- ANNOUNCEMENT BAR ---- */
.ignou-announcement-bar {
    background: linear-gradient(90deg, #232f3e 0%, #37475a 50%, #232f3e 100%);
    background-size: 200% 100%;
    color: #fff;
    text-align: center;
    padding: 7px 0;
    font-size: 13px;
    letter-spacing: .3px;
    position: relative;
    overflow: hidden;
}
.ignou-announcement-text { margin: 0; }

/* ---- CONTAINER ---- */
.ignou-container {
    max-width: var(--ignou-content-width);
    margin: 0 auto;
    padding: 0 16px;
}

/* ---- HEADER ---- */
.ignou-header {
    background: var(--ignou-header-bg);
    position: relative;
    z-index: 1000;
}
.ignou-header-main { padding: 10px 0; }
.ignou-header-inner {
    display: flex;
    align-items: center;
    gap: 16px;
}

/* Logo */
.ignou-header-logo a { color: var(--ignou-header-text); text-decoration: none; }
.ignou-header-logo .custom-logo { max-height: 45px; width: auto; }
.ignou-logo-text { display: flex; flex-direction: column; white-space: nowrap; }
.ignou-logo-primary {
    font-family: var(--ignou-font-heading);
    font-size: 22px;
    font-weight: 800;
    color: var(--ignou-header-text);
    letter-spacing: -.5px;
}
.ignou-logo-tagline { font-size: 11px; color: var(--ignou-text-muted); margin-top: -2px; }

/* Search */
.ignou-header-search { flex: 1; max-width: 720px; position: relative; }
.ignou-search-wrapper {
    display: flex;
    border-radius: var(--ignou-radius);
    overflow: hidden;
    height: 44px;
    box-shadow: 0 0 0 2px var(--ignou-search-btn);
    transition: box-shadow .2s;
}
.ignou-search-wrapper:focus-within {
    box-shadow: 0 0 0 3px var(--ignou-search-btn), 0 4px 12px rgba(37,99,235,.25);
}
.ignou-search-category {
    background: #e6e6e6;
    border: none;
    padding: 0 10px;
    font-size: 13px;
    color: #333;
    cursor: pointer;
    min-width: 80px;
    border-right: 1px solid #ccc;
    outline: none;
}
.ignou-search-input {
    flex: 1;
    border: none;
    padding: 0 14px;
    font-size: 15px;
    outline: none;
    min-width: 0;
    background: #fff;
}
.ignou-search-btn {
    background: var(--ignou-search-btn);
    border: none;
    padding: 0 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    transition: background .2s;
}
.ignou-search-btn:hover { background: var(--ignou-search-btn-hover); }

/* Search Suggestions */
.ignou-search-suggestions {
    position: absolute;
    top: calc(100% + 2px);
    left: 0; right: 0;
    background: #fff;
    border: 1px solid var(--ignou-border);
    border-radius: 0 0 var(--ignou-radius-lg) var(--ignou-radius-lg);
    box-shadow: var(--ignou-shadow-hover);
    z-index: 9999;
    max-height: 420px;
    overflow-y: auto;
}
.ignou-search-loading {
    padding: 14px;
    text-align: center;
    color: var(--ignou-text-muted);
    font-size: 14px;
}
.ignou-suggestion-item {
    display: flex;
    align-items: center;
    padding: 10px 14px;
    gap: 12px;
    border-bottom: 1px solid #f5f5f5;
    cursor: pointer;
    transition: background .15s;
    text-decoration: none;
    color: inherit;
}
.ignou-suggestion-item:hover { background: #f7fafe; text-decoration: none; color: inherit; }
.ignou-suggestion-item img { width: 44px; height: 44px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.ignou-suggestion-info { flex: 1; min-width: 0; }
.ignou-suggestion-title { font-size: 14px; color: var(--ignou-text-dark); display: block; }
.ignou-suggestion-course { font-size: 12px; color: var(--ignou-text-muted); display: block; }
.ignou-suggestion-price { font-size: 13px; color: var(--ignou-price-red); font-weight: 600; }

/* Header Actions */
.ignou-header-actions { display: flex; align-items: center; gap: 6px; }
.ignou-header-action {
    display: flex;
    align-items: center;
    gap: 6px;
    color: var(--ignou-header-text);
    text-decoration: none;
    padding: 6px 8px;
    border: 1px solid transparent;
    border-radius: 3px;
    transition: border-color .2s;
    white-space: nowrap;
}
.ignou-header-action:hover { border-color: var(--ignou-header-text); color: var(--ignou-header-text); text-decoration: none; }
.ignou-header-action svg { flex-shrink: 0; }
.ignou-action-text { display: flex; flex-direction: column; line-height: 1.2; }
.ignou-action-small { font-size: 11px; color: var(--ignou-text-muted); }
.ignou-action-bold { font-size: 13px; font-weight: 700; color: var(--ignou-header-text); }

/* Cart Icon */
.ignou-cart-wrapper { position: relative; }
.ignou-cart-icon-wrapper { position: relative; }
.ignou-cart-count {
    position: absolute;
    top: -6px; right: -6px;
    background: var(--ignou-search-btn);
    color: var(--ignou-header-bg);
    font-size: 12px;
    font-weight: 700;
    min-width: 20px; height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.ignou-cart-count.ignou-cart-pop { animation: cartPop .4s ease; }

/* Mini Cart Flyout */
.ignou-mini-cart-flyout {
    position: absolute;
    top: 100%;
    right: 0;
    width: 340px;
    background: #fff;
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius-lg);
    box-shadow: var(--ignou-shadow-hover);
    z-index: 9999;
    display: none;
    animation: fadeInUp .2s ease;
}
.ignou-cart-wrapper:hover .ignou-mini-cart-flyout { display: block; }
.ignou-mini-cart-contents { padding: 16px; }
.ignou-mini-cart-item {
    display: flex;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid #f5f5f5;
}
.ignou-mini-cart-thumb { width: 50px; flex-shrink: 0; }
.ignou-mini-cart-thumb img { width: 50px; height: 50px; object-fit: cover; border-radius: 4px; }
.ignou-mini-cart-info { flex: 1; }
.ignou-mini-cart-title { font-size: 13px; font-weight: 500; display: block; margin-bottom: 2px; color: var(--ignou-text-dark); }
.ignou-mini-cart-qty { font-size: 12px; color: var(--ignou-text-muted); }
.ignou-mini-cart-total {
    display: flex;
    justify-content: space-between;
    padding: 12px 0 8px;
    font-size: 15px;
    border-top: 1px solid var(--ignou-border);
    margin-top: 8px;
}
.ignou-mini-cart-actions { display: flex; gap: 8px; }
.ignou-btn-mini-cart,
.ignou-btn-mini-checkout {
    flex: 1;
    text-align: center;
    padding: 8px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: var(--ignou-transition);
}
.ignou-btn-mini-cart {
    background: #fff;
    color: var(--ignou-text-dark);
    border: 1px solid var(--ignou-border);
}
.ignou-btn-mini-cart:hover { background: #f5f5f5; text-decoration: none; color: var(--ignou-text-dark); }
.ignou-btn-mini-checkout {
    background: var(--ignou-search-btn);
    color: var(--ignou-header-bg);
    border: 1px solid #c99a2e;
}
.ignou-btn-mini-checkout:hover { background: var(--ignou-search-btn-hover); text-decoration: none; color: var(--ignou-header-bg); }
.ignou-mini-cart-empty { text-align: center; padding: 20px; color: var(--ignou-text-muted); }
.ignou-mini-cart-empty svg { margin: 0 auto 8px; }

/* Mobile Toggle */
.ignou-mobile-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    order: -1;
}
.ignou-hamburger { display: flex; flex-direction: column; gap: 5px; }
.ignou-hamburger span {
    display: block;
    width: 22px; height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: transform .3s, opacity .3s;
}

/* ---- NAV BAR ---- */
.ignou-nav-bar {
    background: var(--ignou-nav-bg);
    border-top: 1px solid rgba(255,255,255,.08);
}
.ignou-nav-menu {
    display: flex;
    list-style: none;
    margin: 0; padding: 0;
}
.ignou-nav-item { position: relative; }
.ignou-nav-link {
    display: flex;
    align-items: center;
    gap: 5px;
    color: #fff;
    padding: 9px 14px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
    text-decoration: none;
    border: 1px solid transparent;
    transition: border-color .2s;
}
.ignou-nav-link:hover { border-color: #fff; color: #fff; text-decoration: none; }
.ignou-all-link { font-weight: 700; }
.ignou-nav-highlight .ignou-nav-link { color: #febd69; }

/* Mega Menu */
.ignou-mega-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: #fff;
    box-shadow: 0 8px 30px rgba(0,0,0,.15);
    border-radius: 0 0 var(--ignou-radius-lg) var(--ignou-radius-lg);
    z-index: 9998;
    min-width: 720px;
    padding: 24px;
    animation: fadeIn .2s ease;
}
.ignou-has-mega-menu:hover .ignou-mega-menu { display: block; }
.ignou-mega-menu-inner { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.ignou-mega-col h4 {
    font-size: 14px;
    font-weight: 700;
    color: var(--ignou-text-dark);
    margin: 0 0 10px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--ignou-search-btn);
}
.ignou-mega-col ul { list-style: none; margin: 0; padding: 0; }
.ignou-mega-col li { margin-bottom: 6px; }
.ignou-mega-col a {
    color: var(--ignou-text-dark);
    font-size: 13px;
    text-decoration: none;
    padding: 3px 0;
    display: block;
    transition: var(--ignou-transition-fast);
}
.ignou-mega-col a:hover { color: var(--ignou-link); padding-left: 4px; }
.ignou-mega-highlight {
    background: linear-gradient(135deg, #fef8ef, #fff5e6);
    border-radius: var(--ignou-radius-lg);
    padding: 16px;
}

/* ---- STICKY HEADER ---- */
.ignou-header--sticky {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 9999;
    animation: slideDown .3s ease;
    box-shadow: 0 2px 10px rgba(0,0,0,.2);
}
body.ignou-has-sticky-header { padding-top: 120px; }

/* ---- BREADCRUMBS ---- */
.ignou-breadcrumbs {
    background: #fff;
    padding: 10px 0;
    font-size: 13px;
    border-bottom: 1px solid var(--ignou-border);
}
.ignou-breadcrumb-sep { margin: 0 6px; color: #999; }
.ignou-breadcrumb-item a { color: var(--ignou-link); }

/* ---- HERO SLIDER ---- */
.ignou-hero-slider {
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #232f3e, #131921);
    max-height: 420px;
}
.ignou-slider-track { position: relative; width: 100%; }
.ignou-slide {
    display: none;
    width: 100%;
    animation: fadeIn .6s ease;
}
.ignou-slide--active { display: block; }
.ignou-slide-link { display: block; }
.ignou-slide-img { width: 100%; height: auto; display: block; object-fit: cover; }
.ignou-slide-placeholder {
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
}
.ignou-slide-placeholder--0 { background: linear-gradient(135deg, #232f3e 0%, #37475a 50%, #1a252f 100%); }
.ignou-slide-placeholder--1 { background: linear-gradient(135deg, #1a3a5c 0%, #2d6fa0 50%, #1a3a5c 100%); }
.ignou-slide-placeholder--2 { background: linear-gradient(135deg, #1a472a 0%, #2d8a5f 50%, #1a472a 100%); }
.ignou-slide-content { text-align: center; color: #fff; max-width: 600px; }
.ignou-slide-title {
    font-family: var(--ignou-font-heading);
    font-size: 34px;
    font-weight: 800;
    margin: 0 0 20px;
    line-height: 1.2;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
}
.ignou-slide-cta {
    display: inline-block;
    background: var(--ignou-cta-btn);
    color: var(--ignou-header-bg);
    padding: 14px 36px;
    border-radius: var(--ignou-radius);
    font-weight: 700;
    font-size: 16px;
    transition: var(--ignou-transition);
    text-decoration: none;
}
.ignou-slide-cta:hover { background: var(--ignou-cta-btn-hover); transform: translateY(-2px); }
.ignou-slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255,255,255,.8);
    border: none;
    cursor: pointer;
    padding: 20px 10px;
    color: #333;
    z-index: 10;
    transition: var(--ignou-transition);
}
.ignou-slider-arrow:hover { background: rgba(255,255,255,.95); }
.ignou-slider-prev { left: 0; border-radius: 0 4px 4px 0; }
.ignou-slider-next { right: 0; border-radius: 4px 0 0 4px; }
.ignou-slider-dots {
    position: absolute;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
}
.ignou-slider-dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    border: 2px solid #fff;
    background: transparent;
    cursor: pointer;
    transition: var(--ignou-transition-fast);
}
.ignou-slider-dot--active { background: #fff; }

/* ---- TRUST BAR ---- */
.ignou-trust-bar { background: #fff; padding: 18px 0; border-bottom: 1px solid var(--ignou-border); }
.ignou-trust-items { display: flex; justify-content: space-around; flex-wrap: wrap; gap: 12px; }
.ignou-trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ignou-text-dark);
    transition: var(--ignou-transition);
}
.ignou-trust-item:hover { transform: translateY(-1px); }
.ignou-trust-icon { font-size: 22px; }

/* ---- SECTION HEADERS ---- */
.ignou-section-header {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.ignou-section-header h2 {
    font-family: var(--ignou-font-heading);
    font-size: 24px;
    font-weight: 700;
    color: var(--ignou-text-dark);
    margin: 0;
    position: relative;
}
.ignou-section-subtitle { font-size: 14px; color: var(--ignou-text-muted); margin: 0; }
.ignou-view-all {
    margin-left: auto;
    font-size: 14px;
    color: var(--ignou-link);
    font-weight: 500;
}

/* ---- PRODUCT SECTIONS ---- */
.ignou-product-section { padding: 36px 0; }
.ignou-featured-products { background: #fff; }
.ignou-bestsellers { background: var(--ignou-body-bg); }
.ignou-on-sale { background: #fff; }

/* ---- CATEGORY SECTION ---- */
.ignou-category-section { padding: 36px 0; background: var(--ignou-body-bg); }
.ignou-category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.ignou-category-card {
    background: #fff;
    border-radius: var(--ignou-radius-lg);
    padding: 28px 16px;
    text-align: center;
    text-decoration: none;
    color: var(--ignou-text-dark);
    box-shadow: var(--ignou-shadow-card);
    transition: var(--ignou-transition);
    border: 1px solid transparent;
}
.ignou-category-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--ignou-shadow-hover);
    text-decoration: none;
    color: var(--ignou-text-dark);
    border-color: var(--ignou-search-btn);
}
.ignou-cat-icon { font-size: 42px; display: block; margin-bottom: 10px; }
.ignou-category-card h3 { font-size: 18px; font-weight: 700; margin: 0 0 4px; }
.ignou-cat-count { font-size: 13px; color: var(--ignou-text-muted); }

/* ---- RECENTLY VIEWED GRID ---- */
.ignou-recently-viewed-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    list-style: none;
    padding: 0;
    margin: 0;
}
@media (max-width: 991px) { .ignou-recently-viewed-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px) { .ignou-recently-viewed-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; } }

/* ---- PRODUCT CARDS ---- */
.ignou-product-card {
    background: var(--ignou-card-bg);
    border-radius: var(--ignou-radius-lg);
    overflow: hidden;
    box-shadow: var(--ignou-shadow-card);
    transition: var(--ignou-transition);
    display: flex;
    flex-direction: column;
    border: 1px solid transparent;
}
.ignou-product-card:hover {
    box-shadow: var(--ignou-shadow-hover);
    transform: translateY(-3px);
    border-color: #e0e0e0;
}
.ignou-card-link { text-decoration: none; color: inherit; flex: 1; }
.ignou-card-link:hover { text-decoration: none; color: inherit; }
.ignou-card-image {
    position: relative;
    padding-top: 100%;
    overflow: hidden;
    background: #fafafa;
}
.ignou-card-thumb {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform .4s cubic-bezier(.4,0,.2,1);
}
.ignou-product-card:hover .ignou-card-thumb { transform: scale(1.06); }
.ignou-card-placeholder {
    position: absolute;
    top: 0; left: 0;
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f5f5f5;
}

/* Quick View Overlay */
.ignou-card-overlay {
    position: absolute;
    bottom: 0; left: 0; right: 0;
    background: linear-gradient(transparent, rgba(0,0,0,.6));
    padding: 20px 12px 10px;
    opacity: 0;
    transition: opacity .3s;
    text-align: center;
}
.ignou-product-card:hover .ignou-card-overlay { opacity: 1; }
.ignou-quick-view-label {
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .5px;
}

/* Badges */
.ignou-sale-badge {
    position: absolute;
    top: 8px; left: 8px;
    background: var(--ignou-sale-red);
    color: #fff;
    padding: 3px 10px;
    font-size: 11px;
    font-weight: 700;
    border-radius: 3px;
    z-index: 2;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.ignou-course-badge {
    position: absolute;
    top: 8px; right: 8px;
    background: var(--ignou-text-dark); /* Changed from header-bg so it stays dark and readable */
    color: #fff;
    padding: 3px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 3px;
    z-index: 2;
}

/* Card Info */
.ignou-card-info { padding: 14px; flex: 1; }
.ignou-card-title {
    font-size: 14px;
    font-weight: 500;
    color: var(--ignou-text-dark);
    margin: 0 0 6px;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2; line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.ignou-card-meta { display: flex; gap: 6px; margin-bottom: 8px; flex-wrap: wrap; }
.ignou-meta-program, .ignou-meta-session {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 3px;
    background: var(--ignou-text-dark); /* Made dark to contrast well against the white card */
    color: #fff;
    font-weight: 500;
}
.ignou-card-rating { display: flex; align-items: center; gap: 4px; margin-bottom: 6px; }
.ignou-stars { display: flex; gap: 1px; }
.ignou-star { font-size: 14px; }
.ignou-star--full { color: var(--ignou-star-yellow); }
.ignou-star--half { color: var(--ignou-star-yellow); opacity: .6; }
.ignou-star--empty { color: #ddd; }
.ignou-rating-count { font-size: 12px; color: var(--ignou-link); }
.ignou-card-price { margin-bottom: 6px; }
.ignou-price-current { font-size: 18px; font-weight: 700; color: var(--ignou-price-red); }
.ignou-price-mrp { font-size: 12px; color: var(--ignou-text-muted); margin-left: 6px; }
.ignou-price-save { font-size: 12px; color: var(--ignou-sale-red); font-weight: 600; margin-left: 4px; }
.ignou-medium-badge {
    display: inline-block;
    font-size: 11px;
    padding: 2px 8px;
    background: #e7f4f5;
    color: var(--ignou-link);
    border-radius: 3px;
    margin-bottom: 6px;
    font-weight: 500;
}
.ignou-session-badge { font-size: 11px; color: var(--ignou-text-muted); }
.ignou-card-delivery { font-size: 12px; color: var(--ignou-success-green); font-weight: 500; }
.ignou-card-actions { padding: 0 14px 14px; }
.ignou-add-to-cart {
    display: block;
    width: 100%;
    padding: 9px;
    background: var(--ignou-cta-btn) !important;
    color: var(--ignou-header-bg) !important;
    border: 1px solid #a88734 !important;
    border-radius: 20px !important;
    font-size: 13px;
    font-weight: 600;
    text-align: center;
    cursor: pointer;
    transition: var(--ignou-transition);
}
.ignou-add-to-cart:hover { background: var(--ignou-cta-btn-hover) !important; box-shadow: 0 2px 5px rgba(0,0,0,.1); }

/* ---- ARCHIVE / SHOP PAGE ---- */
.ignou-archive-page { padding: 20px 0 40px; }
.ignou-archive-layout { display: grid; grid-template-columns: 250px 1fr; gap: 24px; }
.ignou-archive-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 12px;
}
.ignou-archive-title { font-size: 20px; font-weight: 700; margin: 0; }
.ignou-result-count { font-size: 13px; color: var(--ignou-text-muted); margin-left: 8px; }
.ignou-archive-controls { display: flex; align-items: center; gap: 12px; }
.ignou-filter-toggle {
    display: none;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius);
    background: #fff;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
}

/* Active Filter Chips */
.ignou-active-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.ignou-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    background: #e7f4f5;
    color: var(--ignou-link);
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    transition: var(--ignou-transition-fast);
}
.ignou-filter-chip:hover { background: #d0e9eb; text-decoration: none; color: var(--ignou-link); }
.ignou-chip-remove { font-size: 11px; opacity: .7; }
.ignou-chip-clear { background: #ffeae6; color: var(--ignou-sale-red); }
.ignou-chip-clear:hover { background: #fdd; color: var(--ignou-sale-red); }

/* Filter Sidebar */
.ignou-filter-sidebar {
    background: #fff;
    border-radius: var(--ignou-radius-lg);
    padding: 20px;
    box-shadow: var(--ignou-shadow-card);
    align-self: start;
    position: sticky;
    top: 130px;
}
.ignou-filter-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
.ignou-filter-header h3 { font-size: 16px; font-weight: 700; margin: 0; }
.ignou-filter-close { display: none; background: none; border: none; cursor: pointer; }
.ignou-filter-group { margin-bottom: 20px; border-bottom: 1px solid #f0f0f0; padding-bottom: 16px; }
.ignou-filter-title { font-size: 14px; font-weight: 600; margin: 0 0 10px; color: var(--ignou-text-dark); }
.ignou-filter-list { list-style: none; margin: 0; padding: 0; }
.ignou-filter-list li { margin-bottom: 2px; }
.ignou-filter-list a {
    color: var(--ignou-text-dark);
    font-size: 13px;
    text-decoration: none;
    display: flex;
    justify-content: space-between;
    padding: 5px 6px;
    border-radius: 4px;
    transition: var(--ignou-transition-fast);
}
.ignou-filter-list a:hover { color: var(--ignou-link); background: #f7fafe; }
.ignou-filter-active { color: var(--ignou-link) !important; font-weight: 600; background: #e7f4f5; }
.ignou-filter-count { color: var(--ignou-text-muted); font-size: 12px; }
.ignou-filter-scrollable { max-height: 200px; overflow-y: auto; }
.ignou-filter-search-input input {
    width: 100%;
    padding: 7px 10px;
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius);
    font-size: 13px;
    margin-bottom: 8px;
    transition: border-color .2s;
}
.ignou-filter-search-input input:focus { outline: none; border-color: var(--ignou-link); }
.ignou-clear-btn {
    display: block;
    text-align: center;
    padding: 8px;
    color: var(--ignou-sale-red);
    font-size: 13px;
    font-weight: 500;
}

/* ---- SINGLE PRODUCT ---- */
.ignou-single-product-page { padding: 24px 0 40px; }
.ignou-single-layout { display: grid; grid-template-columns: 420px 1fr 280px; gap: 28px; margin-bottom: 36px; }
.ignou-product-image-main {
    background: #fff;
    border-radius: var(--ignou-radius-lg);
    overflow: hidden;
    border: 1px solid var(--ignou-border);
    cursor: zoom-in;
}
.ignou-main-image { width: 100%; height: auto; display: block; }
.ignou-product-placeholder {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 60px 20px; color: #999; text-align: center;
}
.ignou-product-thumbnails { display: flex; gap: 8px; margin-top: 10px; }
.ignou-thumb-item {
    width: 65px; height: 65px;
    border: 2px solid transparent;
    border-radius: var(--ignou-radius);
    overflow: hidden;
    cursor: pointer;
    transition: border-color .2s;
}
.ignou-thumb-item:hover { border-color: var(--ignou-border-dark); }
.ignou-thumb-active { border-color: var(--ignou-link) !important; }
.ignou-thumb-img { width: 100%; height: 100%; object-fit: cover; }
.ignou-pdf-preview-notice {
    display: flex; align-items: center; gap: 8px;
    margin-top: 12px; padding: 10px 14px;
    background: #fef8ef; border-radius: var(--ignou-radius);
    font-size: 12px; color: #866a3a;
    border: 1px solid #f5e6ce;
}

/* Product Details */
.ignou-product-title { font-family: var(--ignou-font-heading); font-size: 26px; font-weight: 600; margin: 0 0 14px; line-height: 1.3; }
.ignou-product-attributes { margin-bottom: 14px; }
.ignou-attr-row { display: flex; gap: 8px; padding: 7px 0; border-bottom: 1px solid #f5f5f5; font-size: 14px; }
.ignou-attr-label { font-weight: 600; min-width: 110px; color: var(--ignou-text-muted); flex-shrink: 0; }
.ignou-attr-value { color: var(--ignou-text-dark); }
.ignou-product-rating { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.ignou-rating-number { font-size: 14px; font-weight: 600; }
.ignou-rating-link { font-size: 13px; color: var(--ignou-link); }
.ignou-divider { border: none; border-top: 1px solid var(--ignou-border); margin: 14px 0; }
.ignou-price-deal { display: flex; align-items: baseline; gap: 10px; }
.ignou-deal-badge {
    background: var(--ignou-sale-red);
    color: #fff;
    padding: 3px 10px;
    border-radius: var(--ignou-radius);
    font-size: 14px;
    font-weight: 700;
}
.ignou-deal-price { font-size: 28px; font-weight: 300; color: var(--ignou-price-red); }
.ignou-price-mrp-line { font-size: 13px; color: var(--ignou-text-muted); margin-top: 4px; }
.ignou-tax-notice { font-size: 12px; color: var(--ignou-text-muted); margin: 4px 0 14px; }
.ignou-short-desc { font-size: 14px; line-height: 1.7; color: var(--ignou-text-dark); margin-bottom: 16px; }

/* Social Share */
.ignou-social-share { display: flex; align-items: center; gap: 8px; margin-top: 16px; padding-top: 16px; border-top: 1px solid #f0f0f0; }
.ignou-share-label { font-size: 13px; font-weight: 600; color: var(--ignou-text-muted); }
.ignou-share-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    border: 1px solid var(--ignou-border);
    background: #fff;
    color: var(--ignou-text-muted);
    transition: var(--ignou-transition);
    text-decoration: none;
    cursor: pointer;
}
.ignou-share-btn:hover { border-color: var(--ignou-link); color: var(--ignou-link); }
.ignou-share-whatsapp:hover { border-color: #25d366; color: #25d366; }
.ignou-share-telegram:hover { border-color: #0088cc; color: #0088cc; }
.ignou-share-twitter:hover { border-color: #1da1f2; color: #1da1f2; }

/* Buy Box */
.ignou-single-buy-box { align-self: start; position: sticky; top: 130px; }
.ignou-buy-box-inner {
    background: #fff;
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius-lg);
    padding: 20px;
    box-shadow: var(--ignou-shadow-card);
}
.ignou-buybox-price { margin-bottom: 8px; }
.ignou-buybox-amount { font-size: 24px; font-weight: 600; color: var(--ignou-price-red); }
.ignou-in-stock { color: var(--ignou-success-green); font-weight: 600; font-size: 16px; }
.ignou-out-of-stock { color: var(--ignou-sale-red); font-weight: 600; }
.ignou-buybox-delivery { margin: 14px 0; font-size: 14px; }
.ignou-delivery-sub { font-size: 12px; color: var(--ignou-text-muted); margin: 2px 0 0; }
.ignou-buybox-form { margin-bottom: 10px; }
.ignou-btn {
    display: block; width: 100%; padding: 11px;
    border-radius: 20px;
    font-size: 14px; font-weight: 600;
    text-align: center;
    cursor: pointer;
    border: none;
    transition: var(--ignou-transition);
}
.ignou-btn-cart {
    background: var(--ignou-cta-btn);
    color: var(--ignou-header-bg);
    border: 1px solid #a88734;
    display: flex; align-items: center; justify-content: center; gap: 8px;
}
.ignou-btn-cart:hover { background: var(--ignou-cta-btn-hover); box-shadow: 0 2px 5px rgba(0,0,0,.1); }
.ignou-btn-buy-now {
    background: var(--ignou-search-btn);
    color: var(--ignou-header-bg);
    border: 1px solid #c99a2e;
}
.ignou-btn-buy-now:hover { background: var(--ignou-search-btn-hover); box-shadow: 0 2px 5px rgba(0,0,0,.1); }
.ignou-buybox-trust { margin-top: 18px; padding-top: 18px; border-top: 1px solid var(--ignou-border); }
.ignou-trust-line { font-size: 13px; color: var(--ignou-text-muted); margin-bottom: 7px; }

/* ---- STICKY MOBILE BUY BAR ---- */
.ignou-mobile-buy-bar {
    display: none;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    background: #fff;
    border-top: 1px solid var(--ignou-border);
    box-shadow: 0 -2px 10px rgba(0,0,0,.1);
    z-index: 9998;
    padding: 10px 16px;
}
.ignou-mobile-buy-bar-inner { display: flex; align-items: center; gap: 10px; max-width: var(--ignou-content-width); margin: 0 auto; }
.ignou-mobile-buy-price { flex-shrink: 0; }
.ignou-mobile-price-amount { font-size: 20px; font-weight: 700; color: var(--ignou-price-red); }
.ignou-mobile-price-mrp { font-size: 12px; color: var(--ignou-text-muted); margin-left: 4px; }
.ignou-mobile-buy-form { flex: 1; }
.ignou-mobile-buy-btn { font-size: 13px !important; padding: 9px !important; }

/* ---- FAQ SECTION ---- */
.ignou-product-faq { margin: 36px 0; }
.ignou-faq-heading {
    display: flex; align-items: center; gap: 8px;
    font-size: 20px; font-weight: 700; margin: 0 0 18px;
}
.ignou-faq-item {
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius-lg);
    margin-bottom: 8px;
    overflow: hidden;
    transition: border-color .2s;
}
.ignou-faq-item:hover { border-color: var(--ignou-border-dark); }
.ignou-faq-question {
    display: flex; justify-content: space-between; align-items: center;
    width: 100%; padding: 14px 18px; background: #fff; border: none;
    font-size: 14px; font-weight: 600; text-align: left; cursor: pointer;
    color: var(--ignou-text-dark); transition: background .2s;
}
.ignou-faq-question:hover { background: #fafafa; }
.ignou-faq-chevron { transition: transform .3s ease; flex-shrink: 0; }
.ignou-faq-item--open .ignou-faq-chevron { transform: rotate(180deg); }
.ignou-faq-answer {
    max-height: 0; overflow: hidden;
    transition: max-height .35s cubic-bezier(.4,0,.2,1), padding .35s ease;
    padding: 0 18px; background: #fafafa;
}
.ignou-faq-item--open .ignou-faq-answer { max-height: 300px; padding: 14px 18px; }
.ignou-faq-answer p { margin: 0; font-size: 14px; line-height: 1.7; color: var(--ignou-text-muted); }

/* ---- WHY CHOOSE US ---- */
.ignou-why-section { padding: 44px 0; background: #fff; }
.ignou-why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.ignou-why-card {
    text-align: center; padding: 28px 16px;
    border: 1px solid var(--ignou-border);
    border-radius: var(--ignou-radius-lg);
    transition: var(--ignou-transition);
}
.ignou-why-card:hover { box-shadow: var(--ignou-shadow-hover); transform: translateY(-4px); border-color: var(--ignou-search-btn); }
.ignou-why-icon { font-size: 40px; margin-bottom: 14px; }
.ignou-why-card h3 { font-size: 16px; font-weight: 700; margin: 0 0 8px; }
.ignou-why-card p { font-size: 13px; color: var(--ignou-text-muted); margin: 0; line-height: 1.6; }

/* ---- 404 PAGE ---- */
.ignou-404-page { padding: 60px 0; }
.ignou-404-content { text-align: center; max-width: 600px; margin: 0 auto; }
.ignou-404-icon { font-size: 80px; margin-bottom: 20px; }
.ignou-404-content h1 { font-size: 28px; margin-bottom: 12px; }
.ignou-404-message { font-size: 15px; color: var(--ignou-text-muted); margin-bottom: 28px; line-height: 1.6; }
.ignou-404-search { margin-bottom: 32px; }
.ignou-404-search-bar { max-width: 480px; margin: 0 auto; height: 44px; border: 2px solid var(--ignou-border); border-radius: var(--ignou-radius); }
.ignou-404-programs { margin-bottom: 32px; }
.ignou-404-programs h3 { margin-bottom: 16px; }
.ignou-404-program-grid { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.ignou-404-program-card {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 18px; background: #fff;
    border: 1px solid var(--ignou-border);
    border-radius: 20px; font-size: 14px;
    font-weight: 500; color: var(--ignou-text-dark);
    text-decoration: none;
    transition: var(--ignou-transition);
}
.ignou-404-program-card:hover { border-color: var(--ignou-link); color: var(--ignou-link); text-decoration: none; }
.ignou-404-home-btn { max-width: 200px; margin: 0 auto; display: block; }

/* ---- PAGE ---- */
.ignou-page { padding: 32px 0 48px; }
.ignou-page-title { margin-bottom: 24px; }
.ignou-page-body { background: #fff; padding: 32px; border-radius: var(--ignou-radius-lg); box-shadow: var(--ignou-shadow-card); line-height: 1.8; }
.ignou-page-body p { margin-bottom: 16px; }

/* ---- FOOTER ---- */
.ignou-back-to-top {
    background: #37475a; text-align: center; padding: 14px; cursor: pointer;
    color: #fff; font-size: 13px; transition: background .2s;
}
.ignou-back-to-top:hover { background: #485769; }
.ignou-footer-main { background: #232f3e; padding: 44px 0; }
.ignou-footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.ignou-footer-col h4 { color: #fff; font-size: 15px; font-weight: 700; margin: 0 0 14px; }
.ignou-footer-col ul { list-style: none; margin: 0; padding: 0; }
.ignou-footer-col li { margin-bottom: 8px; }
.ignou-footer-col a { color: #ddd; font-size: 13px; text-decoration: none; transition: var(--ignou-transition-fast); }
.ignou-footer-col a:hover { color: #fff; text-decoration: underline; }
.ignou-footer-contact p { color: #ddd; font-size: 13px; margin: 0 0 6px; }
.ignou-footer-contact a { color: #ddd; }
.ignou-footer-social { display: flex; gap: 10px; margin: 14px 0; }
.ignou-social-icon {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.3);
    color: #ddd;
    transition: var(--ignou-transition);
    text-decoration: none;
}
.ignou-social-icon:hover { border-color: #fff; color: #fff; background: rgba(255,255,255,.1); text-decoration: none; }
.ignou-trust-badges { margin-top: 12px; }
.ignou-badge { display: block; font-size: 12px; color: #ccc; margin-bottom: 6px; padding: 3px 0; }
.ignou-footer-bottom { background: var(--ignou-header-bg); padding: 18px 0; text-align: center; }
.ignou-copyright { color: #ccc; font-size: 13px; margin: 0 0 4px; }
.ignou-disclaimer { color: #888; font-size: 11px; margin: 0; }

/* ---- MOBILE MENU ---- */
.ignou-mobile-overlay {
    display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,.5); z-index: 10000;
    opacity: 0; transition: opacity .3s;
}
.ignou-mobile-overlay--active { display: block; opacity: 1; }
.ignou-mobile-menu {
    position: fixed; top: 0; left: -320px; width: 310px; height: 100vh;
    background: #fff; z-index: 10001; overflow-y: auto;
    transition: left .3s cubic-bezier(.4,0,.2,1);
    box-shadow: 4px 0 20px rgba(0,0,0,.2);
}
.ignou-mobile-menu--active { left: 0; }
.ignou-mobile-menu-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 16px 18px; background: #232f3e; color: #fff;
}
.ignou-mobile-menu-title { font-size: 16px; font-weight: 600; display: flex; align-items: center; gap: 8px; }
.ignou-mobile-close { background: none; border: none; cursor: pointer; color: #fff; }
.ignou-mobile-menu-body { padding: 16px; }
.ignou-mobile-search {
    display: flex; border: 1px solid var(--ignou-border); border-radius: var(--ignou-radius); overflow: hidden; margin-bottom: 18px;
}
.ignou-mobile-search input { flex: 1; border: none; padding: 10px 12px; font-size: 14px; outline: none; }
.ignou-mobile-search button { background: var(--ignou-search-btn); border: none; padding: 10px 14px; cursor: pointer; }
.ignou-mobile-nav h3 {
    font-size: 12px; font-weight: 700; color: var(--ignou-text-muted);
    text-transform: uppercase; letter-spacing: .5px;
    margin: 18px 0 8px;
}
.ignou-mobile-nav ul { list-style: none; margin: 0; padding: 0; }
.ignou-mobile-nav li { border-bottom: 1px solid #f5f5f5; }
.ignou-mobile-nav a {
    display: flex; justify-content: space-between; padding: 11px 0;
    color: var(--ignou-text-dark); font-size: 14px; text-decoration: none;
}
.ignou-mobile-nav a:hover { color: var(--ignou-link); }
.ignou-mobile-count { color: var(--ignou-text-muted); font-size: 12px; }

/* ---- WooCommerce Overrides ---- */
.woocommerce ul.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.woocommerce ul.products li.product { margin: 0 !important; width: auto !important; float: none !important; }
.woocommerce .woocommerce-ordering select { padding: 8px 12px; border-radius: var(--ignou-radius); border: 1px solid var(--ignou-border); }

/* ---- SINGLE POST PREMIUM LAYOUT ---- */
.ignou-single-post-wrapper { background: #fdfdfd; padding-bottom: 60px; }
.ignou-post-hero { 
    background: linear-gradient(135deg, var(--ignou-nav-bg) 0%, var(--ignou-primary) 100%); 
    padding: 80px 0 140px; text-align: center; position: relative; 
}
.ignou-post-hero::after {
    content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 40px;
    background: linear-gradient(to top, rgba(0,0,0,0.05), transparent);
}
.ignou-post-hero-inner { max-width: 900px; margin: 0 auto; position: relative; z-index: 2; }
.ignou-cat-pill {
    display: inline-block; background: rgba(255, 255, 255, 0.15); color: #fff;
    padding: 6px 16px; font-size: 12px; font-weight: 700; border-radius: 50px;
    text-decoration: none; text-transform: uppercase; letter-spacing: 1px;
    margin: 0 6px 20px; transition: all 0.2s ease; border: 1px solid rgba(255,255,255,0.2);
}
.ignou-cat-pill:hover { background: #fff; color: var(--ignou-primary); text-decoration: none; }
.ignou-post-title-main { font-size: 52px; font-weight: 800; color: #fff; margin: 0 0 24px; line-height: 1.15; letter-spacing: -1.5px; text-shadow: 0 2px 10px rgba(0,0,0,0.1); }
.ignou-post-meta-main { display: flex; align-items: center; justify-content: center; gap: 24px; margin-bottom: 10px; }
.ignou-post-date { font-size: 14px; color: rgba(255,255,255,0.9); font-weight: 500; }
.ignou-meta-reading { display: flex; align-items: center; gap: 6px; font-size: 14px; color: rgba(255,255,255,0.9); font-weight: 500; }
.ignou-post-thumbnail-wrapper { max-width: 1000px; margin: -100px auto -60px; padding: 0 20px; position: relative; z-index: 10; }
.ignou-post-featured-img { width: 100%; height: auto; border-radius: 16px; box-shadow: 0 24px 48px rgba(0,0,0,0.15); display: block; object-fit: cover; }
.ignou-post-body-container { max-width: 800px; margin: 0 auto; background: #ffffff; padding: 100px 60px 60px; border-radius: 20px; box-shadow: 0 10px 40px rgba(0,0,0,0.04); position: relative; z-index: 5; margin-bottom: 60px; }
.ignou-post-content-inner { font-size: 18px; line-height: 1.8; color: #333; }
.ignou-post-content-inner h2 { font-size: 30px; margin: 40px 0 20px; color: var(--ignou-text-dark); font-weight: 700; line-height: 1.3; }
.ignou-post-content-inner h3 { font-size: 24px; margin: 30px 0 16px; color: var(--ignou-text-dark); font-weight: 700; }
.ignou-post-content-inner p { margin-bottom: 24px; }
.ignou-post-content-inner img { border-radius: 8px; margin: 32px 0; max-width: 100%; height: auto; }
.ignou-post-content-inner blockquote { font-size: 22px; font-style: italic; color: var(--ignou-text-dark); border-left: 4px solid var(--ignou-primary); padding: 10px 0 10px 24px; margin: 40px 0; background: #f9fbfd; border-radius: 0 8px 8px 0; }
.ignou-post-content-inner ul, .ignou-post-content-inner ol { margin-bottom: 24px; padding-left: 20px; }
.ignou-post-content-inner li { margin-bottom: 10px; }
.ignou-post-footer { border-top: 1px solid var(--ignou-border); margin-top: 40px; padding-top: 30px; display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center; gap: 20px; }
.ignou-post-tags { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ignou-tags-title { font-weight: 600; color: var(--ignou-text-dark); margin-right: 8px; }
.ignou-post-tags a { display: inline-block; background: #f3f4f6; color: #4b5563; padding: 4px 12px; border-radius: 4px; font-size: 13px; text-decoration: none; transition: all 0.2s; }
.ignou-post-tags a:hover { background: var(--ignou-primary); color: #fff; }
.ignou-post-share { display: flex; align-items: center; gap: 16px; }
.ignou-share-title { font-weight: 600; color: var(--ignou-text-dark); font-size: 14px; }
.ignou-share-buttons { display: flex; gap: 8px; }
.ignou-post-share-btn { display: flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 50px; font-size: 13px; font-weight: 600; color: #fff; text-decoration: none; transition: opacity 0.2s; }
.ignou-post-share-btn:hover { opacity: 0.9; color: #fff; text-decoration: none; }
.ignou-twitter { background: #1DA1F2; }
.ignou-facebook { background: #1877F2; }
.ignou-whatsapp { background: #25D366; }
.ignou-post-author-box { display: flex; align-items: flex-start; gap: 24px; margin-top: 50px; padding: 30px; background: #f9fbfd; border-radius: 12px; }
.ignou-author-box-avatar img { border-radius: 50%; width: 80px; height: 80px; object-fit: cover; }
.ignou-author-name-large { font-size: 20px; margin: 0 0 8px; color: var(--ignou-text-dark); font-weight: 700; }
.ignou-author-bio { font-size: 15px; color: #4b5563; line-height: 1.6; margin-bottom: 12px; }
.ignou-author-all-posts { font-size: 14px; font-weight: 600; color: var(--ignou-primary); text-decoration: none; }
.ignou-author-all-posts:hover { text-decoration: underline; }
.ignou-related-posts { padding: 60px 0; background: #fdfdfd; }
.ignou-section-heading { text-align: center; font-size: 28px; font-weight: 700; color: var(--ignou-text-dark); margin-bottom: 40px; }
.ignou-related-posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.ignou-recent-post-card { background: #fff; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 12px rgba(0,0,0,0.05); text-decoration: none; color: inherit; transition: transform 0.2s ease, box-shadow 0.2s ease; border: 1px solid transparent; }
.ignou-recent-post-card:hover { transform: translateY(-5px); box-shadow: 0 12px 24px rgba(0,0,0,0.1); border-color: #eee; text-decoration: none; color: inherit; }
.ignou-recent-thumb img { width: 100%; height: 200px; object-fit: cover; }
.ignou-recent-content { padding: 24px; }
.ignou-recent-cat { color: var(--ignou-primary); font-size: 12px; font-weight: 600; text-transform: uppercase; margin-bottom: 8px; display: block; }
.ignou-recent-title { font-size: 18px; font-weight: 700; color: var(--ignou-text-dark); margin: 0 0 12px; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ignou-recent-date { font-size: 13px; color: var(--ignou-text-muted); }
.ignou-comments-container { max-width: 800px; margin: 0 auto; padding: 20px 0 60px; }

/* ---- ASSIGNMENT ON DEMAND ---- */
.ignou-aod-wrapper { padding: 60px 0; background: #fdfdfd; }
.ignou-aod-header { text-align: center; margin-bottom: 50px; }
.ignou-aod-title { font-size: 42px; font-weight: 800; color: var(--ignou-text-dark); margin: 0 0 16px; letter-spacing: -1px; }
.ignou-aod-subtitle { font-size: 18px; color: var(--ignou-text-muted); max-width: 600px; margin: 0 auto; line-height: 1.6; }
.ignou-aod-form-box { max-width: 700px; margin: 0 auto; background: #fff; padding: 40px; border-radius: 16px; box-shadow: 0 10px 40px rgba(0,0,0,0.06); }
.ignou-aod-alert { display: flex; align-items: flex-start; gap: 16px; padding: 20px; border-radius: 12px; margin-bottom: 30px; }
.ignou-aod-alert svg { flex-shrink: 0; margin-top: 2px; }
.ignou-aod-alert p { margin: 4px 0 0; font-size: 14px; }
.ignou-aod-success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.ignou-aod-error { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.ignou-aod-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; margin-bottom: 24px; }
.ignou-aod-group { margin-bottom: 24px; display: flex; flex-direction: column; }
.ignou-aod-group label { font-weight: 600; margin-bottom: 8px; font-size: 14px; color: var(--ignou-text-dark); }
.ignou-aod-group input[type="text"], .ignou-aod-group input[type="email"], .ignou-aod-group select, .ignou-aod-group textarea {
    padding: 12px 16px; border: 1px solid var(--ignou-border); border-radius: 8px; font-size: 15px; width: 100%; transition: all 0.2s; background: #fafafa;
}
.ignou-aod-group select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml;utf8,<svg fill='%231E293B' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/><path d='M0 0h24v24H0z' fill='none'/></svg>");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 20px;
    padding-right: 40px;
    cursor: pointer;
}
.ignou-aod-group input:focus, .ignou-aod-group select:focus, .ignou-aod-group textarea:focus { border-color: var(--ignou-primary); background: #fff; outline: none; box-shadow: 0 0 0 3px rgba(26, 101, 143, 0.1); }
.ignou-aod-file-upload { border: 2px dashed var(--ignou-border-dark); border-radius: 8px; padding: 30px; text-align: center; background: #fafafa; transition: border 0.2s; }
.ignou-aod-file-upload:hover { border-color: var(--ignou-primary); }
.ignou-aod-file-upload input[type="file"] { max-width: 100%; cursor: pointer; }
.ignou-file-hint { font-size: 12px; color: var(--ignou-text-muted); margin-top: 10px; }
.ignou-aod-submit-wrap { text-align: center; margin-top: 40px; }
.ignou-aod-submit-btn {
    background: var(--ignou-primary); color: #fff; border: none; padding: 16px 32px; font-size: 16px; font-weight: 700; border-radius: 50px; cursor: pointer;
    display: inline-flex; align-items: center; gap: 10px; transition: transform 0.2s, box-shadow 0.2s; letter-spacing: 0.5px;
}
.ignou-aod-submit-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 20px rgba(26, 101, 143, 0.3); }
.ignou-aod-trust-text { font-size: 13px; color: var(--ignou-text-muted); margin-top: 16px; }

/* ---- RESPONSIVE ---- */
@media (max-width: 992px) {
    .ignou-header-inner { flex-wrap: wrap; }
    .ignou-header-search { order: 3; flex-basis: 100%; max-width: 100%; margin-top: 8px; }
    .ignou-mobile-toggle { display: flex; }
    .ignou-orders-link { display: none; }
    .ignou-action-text { display: none; }
    .ignou-nav-bar { display: none; }
    .ignou-archive-layout { grid-template-columns: 1fr; }
    .ignou-filter-sidebar {
        position: fixed; top: 0; left: -320px; width: 300px; height: 100vh;
        z-index: 10001; overflow-y: auto; border-radius: 0;
        transition: left .3s ease;
    }
    .ignou-filter-sidebar--active { left: 0; }
    .ignou-filter-close { display: block; }
    .ignou-filter-toggle { display: flex; }
    .ignou-single-layout { grid-template-columns: 1fr; }
    .ignou-single-buy-box { position: static; }
    .ignou-category-grid { grid-template-columns: repeat(2, 1fr); }
    .ignou-why-grid { grid-template-columns: repeat(2, 1fr); }
    .ignou-footer-grid { grid-template-columns: repeat(2, 1fr); }
    .ignou-mega-menu { min-width: 100%; }
    .ignou-slide-placeholder { height: 280px; }
    .ignou-slide-title { font-size: 24px; }
    body.ignou-has-sticky-header { padding-top: 80px; }
    .ignou-mini-cart-flyout { display: none !important; }
    .ignou-mobile-buy-bar { display: block; }
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 576px) {
    .ignou-category-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .ignou-why-grid { grid-template-columns: 1fr; }
    .ignou-footer-grid { grid-template-columns: 1fr; }
    .ignou-trust-items { justify-content: center; }
    .ignou-slide-placeholder { height: 220px; padding: 24px; }
    .ignou-slide-title { font-size: 20px; }
    .ignou-slide-cta { padding: 10px 24px; font-size: 14px; }
    .ignou-product-title { font-size: 20px; }
    .ignou-deal-price { font-size: 22px; }
    .ignou-search-category { display: none; }
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 10px; }
}
