/* ═══════════════════════════════════════════════════════════════ NanoSchool – Scholarly Curator WooCommerce Design System v2.1 Fixes audit issues #1–#19 ═══════════════════════════════════════════════════════════════ */ /* ─── Design Tokens ───────────────────────────────────────────── */ .woocommerce, .woocommerce-page { --sc-bg: #f8f9fa; --sc-surface: #ffffff; --sc-surface-soft: #edeeef; --sc-surface-alt: #f3f4f5; --sc-border: #c5c6d0; --sc-borderstrong: #75777f; --sc-text: #191c1d; --sc-text-muted: #44474f; --sc-accent: #00020a; --sc-accent-hover: #0f2f50; --sc-highlight: #e9c176; --sc-highlight-deep: #5d4201; --sc-shadow: 0 24px 48px rgba(17, 24, 39, 0.08); --sc-radius-sm: 12px; --sc-radius-md: 18px; --sc-radius-lg: 24px; --sc-radius-xl: 28px; --sc-transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1); background: var(--sc-bg); color: var(--sc-text); font-family: 'Inter', sans-serif; } /* ─── Global Resets ───────────────────────────────────────────── */ .woocommerce img, .woocommerce-page img { max-width: 100%; height: auto; } .woocommerce a, .woocommerce-page a { color: var(--sc-accent); } .woocommerce *:focus-visible { outline: 2px solid var(--sc-highlight); outline-offset: 2px; border-radius: 4px; } .material-symbols-outlined { font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24; vertical-align: middle; } /* ─── Shell ───────────────────────────────────────────────────── */ .sc-woo-shell { padding: 32px 20px 72px; background: radial-gradient(circle at top left, rgba(216, 226, 255, 0.95), transparent 28%), linear-gradient(180deg, #ffffff 0%, var(--sc-bg) 100%); } .sc-woo-shell__inner { max-width: 1320px; margin: 0 auto; } /* ═══════════════════════════════════════════════════════════════ HERO SECTION ═══════════════════════════════════════════════════════════════ */ .sc-shop__hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 0.92fr); gap: 48px; align-items: center; margin-bottom: 42px; padding: 24px 8px 0; } .sc-shop__hero-copy { max-width: 620px; } .sc-shop__eyebrow, .sc-single-product__categories { font-family: 'Work Sans', sans-serif; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--sc-highlight-deep); } .sc-shop__title, .sc-single-product__title, .woocommerce div.product .related > h2, .woocommerce div.product .upsells > h2 { margin: 0; font-family: 'Manrope', sans-serif; font-weight: 800; line-height: 1.02; letter-spacing: -0.04em; color: inherit; } .sc-shop__title { margin-top: 10px; font-size: clamp(3rem, 5vw, 5rem); color: var(--sc-accent); } .sc-shop__title-accent { color: var(--sc-highlight); } .sc-shop__description { max-width: 560px; margin: 18px 0 0; font-size: 1.08rem; line-height: 1.75; color: var(--sc-text-muted); } .sc-shop__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 24px; } /* ─── Buttons ─────────────────────────────────────────────────── */ .sc-shop__button { display: inline-flex; align-items: center; justify-content: center; min-height: 56px; padding: 0 30px; border-radius: 14px; text-decoration: none; font-family: 'Manrope', sans-serif; font-size: 0.95rem; font-weight: 800; cursor: pointer; transition: transform var(--sc-transition), background-color var(--sc-transition), color var(--sc-transition), box-shadow var(--sc-transition); } .sc-shop__button:hover { transform: translateY(-2px); } /* FIX #1 — "Explore Catalog" button was invisible (black text on black bg). Using !important to override any WooCommerce/theme cascade that resets color. */ .sc-shop__button--primary, body.woocommerce .sc-shop__button--primary, #wrapper .sc-shop__button--primary { background: var(--sc-accent) !important; color: #ffffff !important; box-shadow: 0 18px 30px rgba(0, 2, 10, 0.18); } .sc-shop__button--primary:hover { background: var(--sc-accent-hover) !important; color: #ffffff !important; box-shadow: 0 22px 36px rgba(0, 2, 10, 0.24); } .sc-shop__button--secondary { background: var(--sc-surface-soft); color: var(--sc-accent); border: 1px solid rgba(197, 198, 208, 0.7); } .sc-shop__button--secondary:hover { background: var(--sc-surface); border-color: var(--sc-border-strong); } /* ─── Hero Media ──────────────────────────────────────────────── */ .sc-shop__hero-media { position: relative; overflow: hidden; aspect-ratio: 4 / 3; border-radius: var(--sc-radius-lg); box-shadow: 0 26px 46px rgba(17, 24, 39, 0.16); } .sc-shop__hero-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 8s ease; } .sc-shop__hero:hover .sc-shop__hero-media img { transform: scale(1.04); } .sc-shop__hero-media-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0, 2, 10, 0.35), transparent 55%); pointer-events: none; } /* ═══════════════════════════════════════════════════════════════ SHOP LAYOUT — Sidebar + Content ═══════════════════════════════════════════════════════════════ */ .sc-shop__layout { display: grid; grid-template-columns: minmax(240px, 280px) minmax(0, 1fr); gap: 28px; align-items: start; } .sc-shop__sidebar { position: sticky; top: 32px; } /* ─── Panels ──────────────────────────────────────────────────── */ .sc-panel { padding: 24px; background: var(--sc-surface); border: 1px solid rgba(197, 198, 208, 0.55); border-radius: 20px; box-shadow: 0 10px 24px rgba(17, 24, 39, 0.04); } .sc-panel + .sc-panel { margin-top: 20px; } .sc-panel__title { margin: 0 0 16px; font-family: 'Manrope', sans-serif; font-size: 1.05rem; font-weight: 800; color: var(--sc-accent); } .sc-panel__title--icon { display: flex; align-items: center; gap: 10px; } /* ─── Filter Groups ───────────────────────────────────────────── */ .sc-filter-group__label { display: block; margin-bottom: 14px; font-family: 'Work Sans', sans-serif; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sc-text-muted); } /* ─── Term List (Discipline Filters) ──────────────────────────── */ .sc-term-list { margin: 0; padding: 0; list-style: none; } .sc-term-link { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border: 1px solid transparent; border-radius: 16px; color: var(--sc-text); text-decoration: none; transition: var(--sc-transition); } .sc-term-link:hover, .sc-term-link.is-active { background: var(--sc-surface-alt); border-color: rgba(197, 198, 208, 0.75); } .sc-term-link__indicator { flex: 0 0 16px; width: 16px; height: 16px; border: 2px solid var(--sc-border-strong); border-radius: 5px; transition: var(--sc-transition); } .sc-term-link.is-active .sc-term-link__indicator, .sc-term-link:hover .sc-term-link__indicator { border-color: var(--sc-accent); background: var(--sc-accent); } .sc-term-link__text { flex: 1 1 auto; } .sc-term-link__count { font-size: 0.78rem; color: var(--sc-text-muted); } /* ─── Search Form in Sidebar ──────────────────────────────────── */ .sc-search-form { position: relative; display: flex; align-items: center; } .sc-search-form__input { width: 100%; min-height: 46px; padding: 10px 16px 10px 42px; border: 1px solid var(--sc-border); border-radius: 14px; background: var(--sc-surface); font-family: 'Inter', sans-serif; font-size: 0.9rem; color: var(--sc-text); transition: border-color var(--sc-transition), box-shadow var(--sc-transition); } .sc-search-form__input::placeholder { color: var(--sc-text-muted); opacity: 0.7; } .sc-search-form__input:focus { outline: none; border-color: var(--sc-accent); box-shadow: 0 0 0 3px rgba(0, 2, 10, 0.08); } .sc-search-form__icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); font-size: 20px; color: var(--sc-text-muted); pointer-events: none; } .sc-search-form__submit { position: absolute; right: 6px; top: 50%; transform: translateY(-50%); min-height: 34px; padding: 0 14px; border: 0; border-radius: 10px; background: var(--sc-accent); color: #ffffff; font-family: 'Manrope', sans-serif; font-size: 0.78rem; font-weight: 700; cursor: pointer; transition: background-color var(--sc-transition); } .sc-search-form__submit:hover { background: var(--sc-accent-hover); } /* ─── Tag Cloud ───────────────────────────────────────────────── */ .sc-tag-list { display: flex; flex-wrap: wrap; gap: 10px; } .sc-tag { display: inline-flex; align-items: center; min-height: 36px; padding: 0 14px; background: var(--sc-surface-soft); border: 1px solid rgba(197, 198, 208, 0.7); border-radius: 999px; text-decoration: none; color: var(--sc-accent); font-size: 0.8rem; white-space: nowrap; max-width: 100%; overflow: hidden; text-overflow: ellipsis; transition: background-color var(--sc-transition), color var(--sc-transition); } .sc-tag:hover { background: var(--sc-accent); color: #ffffff; } /* ═══════════════════════════════════════════════════════════════ SHOP TOOLBAR ═══════════════════════════════════════════════════════════════ */ .sc-shop-toolbar { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 16px; margin-bottom: 20px; padding: 18px 20px; background: rgba(255, 255, 255, 0.82); border: 1px solid rgba(197, 198, 208, 0.8); border-radius: 20px; backdrop-filter: blur(8px); } .sc-shop-toolbar__count { margin: 0; font-family: 'Work Sans', sans-serif; font-size: 0.92rem; color: var(--sc-text-muted); } .sc-shop-toolbar__count strong { color: var(--sc-accent); } .sc-shop-toolbar__sort { display: flex; align-items: center; gap: 10px; font-family: 'Work Sans', sans-serif; font-size: 0.74rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sc-text-muted); } .woocommerce .woocommerce-ordering { margin: 0; } .woocommerce .woocommerce-ordering select { min-height: 42px; padding: 0 14px 0 0; border: 0; background: transparent; color: var(--sc-accent); font-family: 'Manrope', sans-serif; font-size: 0.95rem; font-weight: 800; cursor: pointer; } /* ═══════════════════════════════════════════════════════════════ PRODUCT GRID ═══════════════════════════════════════════════════════════════ */ .woocommerce ul.products { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; margin: 0; padding: 0; list-style: none; } .woocommerce ul.products::before, .woocommerce ul.products::after { display: none; } /* ─── Product Card ────────────────────────────────────────────── */ body.woocommerce ul.products li.product.sc-product-card, body.woocommerce-page ul.products li.product.sc-product-card { display: flex !important; flex-direction: column !important; width: 100% !important; max-width: 100% !important; min-width: 250px !important; margin: 0 !important; float: none !important; clear: none !important; padding: 0 !important; list-style: none !important; background: var(--sc-surface) !important; border: 1px solid rgba(197, 198, 208, 0.55) !important; } .woocommerce ul.products li.product.sc-product-card:hover { transform: translateY(-4px); box-shadow: 0 20px 40px rgba(25, 28, 29, 0.08); } /* ─── Card Image ──────────────────────────────────────────────── */ .sc-product-card__image { position: relative; display: block; aspect-ratio: 16 / 10; overflow: hidden; background: #ece7dc; } .sc-product-card__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; } .sc-product-card:hover .sc-product-card__image img { transform: scale(1.05); } /* FIX #9 — Badge truncation. Max 3 words, capped width to prevent overflow. */ .sc-product-card__badge { position: absolute; top: 16px; right: 16px; display: inline-flex; align-items: center; max-width: calc(100% - 32px); min-height: 30px; padding: 0 12px; background: rgba(255, 255, 255, 0.92); backdrop-filter: blur(6px); border-radius: 999px; color: var(--sc-accent); font-family: 'Work Sans', sans-serif; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } /* ─── Card Body ───────────────────────────────────────────────── */ .sc-product-card__body { display: flex; flex-direction: column; gap: 12px; min-height: 260px; padding: 20px; } .sc-product-card__meta, .sc-single-product__meta, .woocommerce .product_meta { color: var(--sc-text-muted); font-size: 0.82rem; line-height: 1.6; /* FIX #10 — Prevent category breadcrumbs from overflowing */ overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sc-product-card__meta a { color: var(--sc-text-muted); text-decoration: none; } .sc-product-card__meta a:hover { color: var(--sc-accent); } .sc-product-card__title { margin: 0; font-family: 'Manrope', sans-serif; font-size: 1.25rem; font-weight: 800; line-height: 1.25; /* FIX #10 — Prevent long titles from blowing out card */ display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; } .sc-product-card__title a { color: var(--sc-text); text-decoration: none; transition: color var(--sc-transition); } .sc-product-card__title a:hover { color: #314671; } .sc-product-card__excerpt { margin: 0; color: var(--sc-text-muted); font-size: 0.9rem; line-height: 1.7; /* Clamp to 3 lines */ display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; } .sc-product-card__readmore { display: inline-block; margin-left: 6px; color: var(--sc-accent); font-family: 'Work Sans', sans-serif; font-size: 0.82rem; font-weight: 700; text-decoration: none; white-space: nowrap; } .sc-product-card__readmore:hover { text-decoration: underline; } /* ─── Card Footer ─────────────────────────────────────────────── */ .sc-product-card__footer { display: flex; justify-content: space-between; align-items: end; gap: 16px; margin-top: auto; padding-top: 16px; border-top: 1px solid rgba(197, 198, 208, 0.45); } .sc-product-card__price .price, .sc-single-product__price .price { color: var(--sc-accent); font-size: 1.5rem; font-weight: 800; } .sc-product-card__price .price del { color: var(--sc-text-muted); font-size: 0.9rem; font-weight: 500; opacity: 0.7; } /* ─── Global Buttons ──────────────────────────────────────────── */ .woocommerce ul.products li.product .button, .woocommerce div.product form.cart .button, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button, .woocommerce #respond input#submit { min-height: 46px; padding: 12px 20px; border: 0; border-radius: 14px; background: var(--sc-accent); color: #ffffff; font-family: 'Manrope', sans-serif; font-weight: 800; line-height: 1.1; cursor: pointer; transition: background-color var(--sc-transition), transform var(--sc-transition); } .woocommerce ul.products li.product .button:hover, .woocommerce div.product form.cart .button:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover, .woocommerce #respond input#submit:hover { background: var(--sc-accent-hover); color: #ffffff; transform: translateY(-1px); } /* Enroll button — gold accent */ .sc-product-card__button { background: var(--sc-highlight) !important; color: var(--sc-highlight-deep) !important; flex-shrink: 0; white-space: nowrap; } .sc-product-card__button:hover { background: #f0cf8d !important; color: var(--sc-highlight-deep) !important; } /* ═══════════════════════════════════════════════════════════════ SINGLE PRODUCT PAGE ═══════════════════════════════════════════════════════════════ */ .sc-single-page { min-width: 0; } .sc-single-product__hero { display: grid; grid-template-columns: minmax(320px, 0.82fr) minmax(0, 1.08fr); gap: 36px; align-items: start; } .sc-single-product__gallery, .sc-single-product__summary, .sc-single-product__details { min-width: 0; } .sc-single-product__gallery { max-width: 560px; margin: 0 auto; padding: 18px; background: var(--sc-surface); border: 1px solid var(--sc-border); border-radius: var(--sc-radius-xl); box-shadow: 0 16px 36px rgba(17, 24, 39, 0.05); } .sc-single-product__summary { padding: 28px; background: rgba(255, 255, 255, 0.88); border: 1px solid var(--sc-border); border-radius: var(--sc-radius-xl); box-shadow: 0 16px 36px rgba(17, 24, 39, 0.05); } .sc-single-product__summary .price { display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px; } .sc-single-product__title { margin-top: 10px; color: var(--sc-text); font-size: clamp(2.15rem, 3vw, 3.55rem); } .sc-single-product__rating { margin-top: 16px; } .sc-single-product__price { margin-top: 18px; padding: 18px 20px; background: var(--sc-surface-soft); border: 1px solid var(--sc-border); border-radius: var(--sc-radius-md); } .sc-single-product__excerpt { margin-top: 18px; color: var(--sc-text-muted); font-size: 1rem; line-height: 1.8; } /* ─── Features List ───────────────────────────────────────────── */ .sc-single-product__features { display: grid; gap: 10px; margin: 22px 0 0; padding: 0; list-style: none; } .sc-single-product__features li { padding-left: 26px; position: relative; color: var(--sc-text); } .sc-single-product__features li::before { content: ""; position: absolute; top: 10px; left: 0; width: 10px; height: 10px; border-radius: 999px; background: var(--sc-highlight); } /* ─── Support Cards ───────────────────────────────────────────── */ .sc-single-product__support { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-top: 20px; } .sc-single-product__support-card { padding: 14px 16px; background: #ffffff; border: 1px solid var(--sc-border); border-radius: var(--sc-radius-md); transition: box-shadow var(--sc-transition); } .sc-single-product__support-card:hover { box-shadow: 0 8px 20px rgba(17, 24, 39, 0.06); } .sc-single-product__support-card strong { display: block; margin-top: 4px; color: var(--sc-text); } .sc-single-product__support-label { font-family: 'Work Sans', sans-serif; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sc-text-muted); } /* ─── Add to Cart ─────────────────────────────────────────────── */ .sc-single-product__cart { margin-top: 24px; } .woocommerce div.product form.cart { display: flex; flex-wrap: wrap; align-items: stretch; gap: 12px; margin-bottom: 0; } .woocommerce div.product form.cart .variations { width: 100%; margin-bottom: 14px; border: 0; } .woocommerce div.product form.cart .variations td, .woocommerce div.product form.cart .variations th { display: block; width: 100%; padding: 0 0 8px; border: 0; } .woocommerce div.product form.cart .variations select { width: 100%; } .woocommerce div.product form.cart div.quantity { float: none; margin: 0; } .woocommerce div.product form.cart .quantity .qty { min-height: 46px; width: 86px; padding: 10px 12px; border: 1px solid var(--sc-border-strong); border-radius: 14px; background: #ffffff; } .sc-single-product__meta { margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--sc-border); } /* ─── Details / Certificate ───────────────────────────────────── */ .sc-single-product__details { display: grid; grid-template-columns: minmax(220px, 280px) minmax(0, 1fr); gap: 28px; align-items: start; margin-top: 36px; } .sc-single-product__certificate, .sc-single-product__tabs-wrap { min-width: 0; } .sc-certificate-card { padding: 20px 18px; background: linear-gradient(180deg, #1d365b 0%, #10213a 100%); border-radius: 22px; box-shadow: 0 18px 36px rgba(16, 33, 58, 0.2); color: #ffffff; } .sc-certificate-card__image-wrap { overflow: hidden; border-radius: 16px; background: rgba(255, 255, 255, 0.12); } .sc-certificate-card__image { display: block; width: 100%; aspect-ratio: 3 / 4; object-fit: cover; } .sc-certificate-card__title { margin: 18px 0 12px; font-family: 'Manrope', sans-serif; font-size: 1.1rem; font-weight: 800; color: #ffffff; } .sc-certificate-card__list { margin: 0; padding-left: 18px; color: rgba(255, 255, 255, 0.82); line-height: 1.7; font-size: 0.92rem; } .sc-certificate-card__link { display: inline-flex; align-items: center; justify-content: center; min-height: 42px; margin-top: 18px; padding: 0 16px; border-radius: var(--sc-radius-sm); background: rgba(255, 255, 255, 0.12); color: #ffffff; text-decoration: none; font-family: 'Manrope', sans-serif; font-size: 0.9rem; font-weight: 700; transition: background-color var(--sc-transition); } .sc-certificate-card__link:hover { background: rgba(255, 255, 255, 0.2); color: #ffffff; } /* ─── Tabs ────────────────────────────────────────────────────── */ .sc-single-product__tabs-wrap { padding: 28px; background: var(--sc-surface); border: 1px solid var(--sc-border); border-radius: var(--sc-radius-xl); box-shadow: 0 16px 36px rgba(17, 24, 39, 0.05); } .woocommerce div.product .woocommerce-tabs ul.tabs { margin: 0 0 24px; padding: 0; list-style: none; border-bottom: 1px solid var(--sc-border); } .woocommerce div.product .woocommerce-tabs ul.tabs li { margin: 0 18px 0 0; padding: 0; background: transparent; border: 0; } .woocommerce div.product .woocommerce-tabs ul.tabs li::before, .woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; } .woocommerce div.product .woocommerce-tabs ul.tabs li a { padding: 12px 4px; color: var(--sc-text-muted); font-family: 'Manrope', sans-serif; font-size: 0.9rem; font-weight: 700; transition: color var(--sc-transition); } .woocommerce div.product .woocommerce-tabs li.active a { color: var(--sc-accent); box-shadow: inset 0 -2px 0 var(--sc-accent); } .woocommerce div.product .woocommerce-tabs .panel { margin: 0; } /* ═══════════════════════════════════════════════════════════════ MISC WOO ELEMENTS ═══════════════════════════════════════════════════════════════ */ .woocommerce .woocommerce-breadcrumb { margin: 0 0 20px; color: var(--sc-text-muted); font-size: 0.92rem; } .woocommerce .woocommerce-breadcrumb a { color: var(--sc-accent); } .woocommerce div.product div.images, .woocommerce div.product div.summary { float: none; width: auto; margin: 0; } .woocommerce div.product div.images .flex-control-thumbs { display: grid; grid-template-columns: repeat(auto-fit, minmax(72px, 1fr)); gap: 10px; margin-top: 14px; } .woocommerce div.product div.images .woocommerce-product-gallery__wrapper, .woocommerce div.product div.images .woocommerce-product-gallery__image a, .woocommerce div.product div.images .woocommerce-product-gallery__image img { border-radius: 20px; } .woocommerce div.product div.images .woocommerce-product-gallery__image img, .woocommerce div.product div.images img.wp-post-image { width: 100%; max-height: 360px; object-fit: cover; } .woocommerce .related.products, .woocommerce .up-sells.upsells.products { margin-top: 42px; } .woocommerce .related.products ul.products, .woocommerce .up-sells.upsells.products ul.products { margin-top: 20px; } /* ─── Pagination FIX #8 — Remove bullet points ───────────────── */ .woocommerce nav.woocommerce-pagination ul { display: flex; gap: 10px; justify-content: center; margin: 32px 0 0; padding: 0; border: 0; list-style: none !important; } .woocommerce nav.woocommerce-pagination ul li { border: 0; list-style: none !important; } .woocommerce nav.woocommerce-pagination ul li::marker { content: none; display: none; } .woocommerce nav.woocommerce-pagination ul li .page-numbers { display: inline-flex; justify-content: center; align-items: center; width: 42px; height: 42px; border: 1px solid var(--sc-border); border-radius: 999px; background: #ffffff; text-decoration: none; font-weight: 600; transition: background-color var(--sc-transition), color var(--sc-transition), border-color var(--sc-transition); } .woocommerce nav.woocommerce-pagination ul li .page-numbers:hover { background: var(--sc-surface-alt); border-color: var(--sc-border-strong); } .woocommerce nav.woocommerce-pagination ul li .current { background: var(--sc-accent); color: #ffffff; border-color: var(--sc-accent); } /* ─── Notices ─────────────────────────────────────────────────── */ .woocommerce-message, .woocommerce-info, .woocommerce-error { margin: 0 0 20px; padding: 16px 18px 16px 48px; border: 1px solid var(--sc-border); border-left: 4px solid var(--sc-accent); border-radius: var(--sc-radius-md); background: #ffffff; box-shadow: 0 10px 24px rgba(17, 24, 39, 0.04); } /* ─── Tables ──────────────────────────────────────────────────── */ .woocommerce table.shop_table, .woocommerce-page table.shop_table { border-collapse: separate; border-spacing: 0; overflow: hidden; border: 1px solid var(--sc-border); border-radius: var(--sc-radius-lg); background: #ffffff; } .woocommerce table.shop_table th, .woocommerce table.shop_table td { padding: 16px 18px; border-color: var(--sc-border); } /* ─── Cart / Checkout ─────────────────────────────────────────── */ .woocommerce-cart .cart-collaterals .cart_totals, .woocommerce-checkout #order_review, .woocommerce-account .woocommerce-MyAccount-content, .woocommerce-account .woocommerce-MyAccount-navigation { padding: 24px; background: #ffffff; border: 1px solid var(--sc-border); border-radius: var(--sc-radius-lg); box-shadow: 0 12px 30px rgba(17, 24, 39, 0.05); } .woocommerce-account .woocommerce-MyAccount-navigation ul { margin: 0; padding: 0; list-style: none; } .woocommerce-account .woocommerce-MyAccount-navigation a { display: block; padding: 12px 14px; border-radius: 14px; text-decoration: none; } .woocommerce-account .woocommerce-MyAccount-navigation .is-active a, .woocommerce-account .woocommerce-MyAccount-navigation a:hover { background: var(--sc-surface-soft); } /* ─── Forms ───────────────────────────────────────────────────── */ .woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select, .woocommerce .select2-container--default .select2-selection--single, .woocommerce .select2-container--default .select2-selection--multiple { min-height: 48px; border: 1px solid var(--sc-border-strong); border-radius: 14px; background: #ffffff; } .woocommerce form .form-row textarea { min-height: 140px; padding-top: 14px; } .woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .woocommerce form .form-row select { padding: 12px 14px; } .woocommerce-checkout .col2-set, .woocommerce-account .woocommerce { display: grid; gap: 24px; } /* ═══════════════════════════════════════════════════════════════ FOOTER ═══════════════════════════════════════════════════════════════ */ .sc-shop-footer { margin-top: 64px; padding: 48px 24px 24px; background: #020913; border-radius: var(--sc-radius-xl); color: #ffffff; } .sc-shop-footer__grid { display: grid; grid-template-columns: minmax(0, 1.2fr) repeat(3, minmax(0, 1fr)); gap: 28px; } .sc-shop-footer__brand p, .sc-shop-footer p, .sc-shop-footer a, .sc-shop-footer span { color: rgba(255, 255, 255, 0.72); } .sc-shop-footer__logo { display: inline-block; font-family: 'Manrope', sans-serif; font-size: 1.1rem; font-weight: 800; color: #ffffff; } .sc-shop-footer h3 { margin: 0 0 14px; font-family: 'Manrope', sans-serif; font-size: 0.95rem; font-weight: 800; color: #ffffff; } .sc-shop-footer a, .sc-shop-footer p { display: block; margin: 0 0 10px; text-decoration: none; line-height: 1.7; } .sc-shop-footer a:hover { color: var(--sc-highlight); } .sc-shop-footer__bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 28px; padding-top: 18px; border-top: 1px solid rgba(255, 255, 255, 0.08); font-size: 0.82rem; } .sc-shop-footer__bottom-meta { display: flex; gap: 18px; } /* ─── Scroll Anchor Offset ────────────────────────────────────── */ #sc-shop-grid { scroll-margin-top: 20px; } #sc-sidebar-filters { scroll-margin-top: 20px; } /* ═══════════════════════════════════════════════════════════════ RESPONSIVE — TABLET ═══════════════════════════════════════════════════════════════ */ @media (max-width: 1100px) { .sc-shop__hero, .sc-shop__layout, .sc-single-product__hero, .sc-single-product__details, .sc-shop-footer__grid { grid-template-columns: 1fr; } .sc-shop__sidebar { position: static; } .sc-single-product__gallery { max-width: none; } } @media (max-width: 860px) { .woocommerce ul.products { grid-template-columns: repeat(2, minmax(0, 1fr)); } .sc-panel, .sc-single-product__gallery, .sc-single-product__summary, .sc-single-product__tabs-wrap, .sc-shop-footer { padding: 22px; border-radius: 22px; } .sc-single-product__support { grid-template-columns: 1fr; } .sc-certificate-card { padding: 18px 16px; } } /* ═══════════════════════════════════════════════════════════════ RESPONSIVE — MOBILE ═══════════════════════════════════════════════════════════════ */ @media (max-width: 640px) { .sc-woo-shell { padding: 24px 14px 48px; } .woocommerce ul.products { grid-template-columns: 1fr; } /* FIX #10 — Mobile card overflow: ensure everything stays within viewport */ .sc-product-card__meta { font-size: 0.78rem; } .sc-product-card__body { padding: 16px; min-height: auto; } .sc-product-card__title { font-size: 1.15rem; } .sc-shop__actions, .sc-shop-toolbar, .sc-shop-toolbar__sort, .sc-product-card__footer, .woocommerce div.product form.cart, .sc-shop-footer__bottom, .sc-shop-footer__bottom-meta { flex-direction: column; align-items: stretch; } .sc-shop__button { width: 100%; text-align: center; } .sc-shop__title { font-size: 2.5rem; } .sc-single-product__title { font-size: 2.35rem; } .woocommerce div.product div.images .woocommerce-product-gallery__image img, .woocommerce div.product div.images img.wp-post-image { max-height: 280px; } .sc-single-product__gallery, .sc-single-product__summary, .sc-single-product__tabs-wrap, .sc-shop-footer { padding: 18px; } .sc-certificate-card__image { aspect-ratio: 4 / 5; } .sc-shop-footer__grid { gap: 32px; } .sc-product-card__footer { flex-direction: row; align-items: center; } .sc-product-card__button { min-width: 100px; } } /* ═══════════════════════════════════════════════════════════════ v3.0 — NEW COMPONENTS (SEO/AEO/GEO + UI Enhancement Pass) ═══════════════════════════════════════════════════════════════ */ /* ─── Breadcrumb ──────────────────────────────────────────────── */ .sc-breadcrumb { padding: 14px 0 0; margin-bottom: 8px; } .sc-breadcrumb__list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 4px; font-size: 0.8rem; color: var(--sc-text-muted); } .sc-breadcrumb__item a { color: var(--sc-text-muted); text-decoration: none; transition: color var(--sc-transition); } .sc-breadcrumb__item a:hover { color: var(--sc-accent); } .sc-breadcrumb__item--current { color: var(--sc-text); font-weight: 500; } .sc-breadcrumb__sep { color: var(--sc-border-strong); user-select: none; } .sc-breadcrumb--single { padding: 24px 0 0; margin-bottom: 12px; } /* ─── Stats Bar ───────────────────────────────────────────────── */ .sc-shop__stats { display: flex; align-items: center; gap: 0; margin: 24px 0; padding: 16px 20px; background: var(--sc-surface); border-radius: var(--sc-radius-md); border: 1px solid var(--sc-border); box-shadow: var(--sc-shadow); width: fit-content; } .sc-stat { display: flex; flex-direction: column; align-items: center; padding: 0 20px; text-align: center; } .sc-stat__number { font-family: 'Manrope', sans-serif; font-size: 1.25rem; font-weight: 800; color: var(--sc-accent); line-height: 1.1; } .sc-stat__label { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--sc-text-muted); margin-top: 3px; } .sc-stat__divider { width: 1px; height: 32px; background: var(--sc-border); flex-shrink: 0; } /* ─── Trust Bar ───────────────────────────────────────────────── */ .sc-trust-bar { background: var(--sc-accent); color: #ffffff; padding: 12px 0; margin: 0 -20px 36px; overflow: hidden; } .sc-trust-bar__inner { max-width: 1320px; margin: 0 auto; padding: 0 20px; display: flex; align-items: center; justify-content: center; flex-wrap: wrap; gap: 24px; } .sc-trust-item { display: flex; align-items: center; gap: 7px; font-size: 0.78rem; font-weight: 600; letter-spacing: 0.02em; opacity: 0.92; white-space: nowrap; } .sc-trust-item__icon { width: 15px; height: 15px; flex-shrink: 0; stroke: var(--sc-highlight); } /* ─── Star Ratings ────────────────────────────────────────────── */ .sc-product-card__rating, .sc-sp-rating { display: flex; align-items: center; gap: 3px; margin-bottom: 10px; } .sc-star { font-size: 0.9rem; line-height: 1; } .sc-star--full { color: #f59e0b; } .sc-star--half { color: #f59e0b; opacity: 0.7; } .sc-star--empty { color: var(--sc-border-strong); } .sc-product-card__rating-count, .sc-sp-rating__label { font-size: 0.78rem; color: var(--sc-text-muted); margin-left: 4px; } /* ─── Level / Duration Pills ──────────────────────────────────── */ .sc-pill { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 999px; font-size: 0.72rem; font-weight: 600; line-height: 1.4; } .sc-pill--level { background: #e0f2fe; color: #0369a1; } .sc-pill--duration { background: #f0fdf4; color: #15803d; } .sc-product-card__pills { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; } /* ─── Card Hover Overlay ──────────────────────────────────────── */ .sc-product-card__image { position: relative; display: block; overflow: hidden; } .sc-product-card__overlay { position: absolute; inset: 0; background: rgba(0, 2, 10, 0.72); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity var(--sc-transition); border-radius: inherit; } .sc-product-card__image:hover .sc-product-card__overlay, .sc-product-card__image:focus-within .sc-product-card__overlay { opacity: 1; } @media (prefers-reduced-motion: reduce) { .sc-product-card__overlay { transition: none; } } .sc-product-card__overlay-text { color: #ffffff; font-size: 0.85rem; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; padding: 10px 20px; border: 2px solid rgba(255,255,255,0.6); border-radius: var(--sc-radius-sm); } /* ─── FAQ Panel (sidebar + full-width) ────────────────────────── */ .sc-faq-panel .sc-panel__title { font-size: 0.85rem; } .sc-faq-list { display: flex; flex-direction: column; gap: 2px; } .sc-faq-item { border-radius: var(--sc-radius-sm); border: 1px solid var(--sc-border); background: var(--sc-surface); overflow: hidden; transition: box-shadow var(--sc-transition); } .sc-faq-item[open] { box-shadow: 0 4px 16px rgba(0,0,0,0.06); } .sc-faq-item__q { list-style: none; cursor: pointer; padding: 12px 14px; font-size: 0.82rem; font-weight: 600; color: var(--sc-text); display: flex; align-items: center; justify-content: space-between; gap: 8px; user-select: none; transition: background var(--sc-transition), color var(--sc-transition); } .sc-faq-item__q::-webkit-details-marker { display: none; } .sc-faq-item:hover .sc-faq-item__q, .sc-faq-item[open] .sc-faq-item__q { background: var(--sc-surface-alt); color: var(--sc-accent-hover); } .sc-faq-item[open] .sc-faq-item__chevron svg { transform: rotate(180deg); } .sc-faq-item__chevron svg { flex-shrink: 0; transition: transform var(--sc-transition); } @media (prefers-reduced-motion: reduce) { .sc-faq-item__chevron svg { transition: none; } } .sc-faq-item__a { margin: 0; padding: 10px 14px 14px; font-size: 0.8rem; color: var(--sc-text-muted); line-height: 1.6; } /* Full-width FAQ section on single product */ .sc-single-product__faq { margin-top: 56px; padding: 48px 0; border-top: 1px solid var(--sc-border); } .sc-faq-container { max-width: 720px; margin: 0 auto; } .sc-faq-title { font-family: 'Manrope', sans-serif; font-size: 1.5rem; font-weight: 800; margin-bottom: 24px; color: var(--sc-text); } .sc-single-product__faq .sc-faq-item__q { font-size: 0.92rem; padding: 16px 20px; } .sc-single-product__faq .sc-faq-item__a { font-size: 0.88rem; padding: 12px 20px 20px; } /* ─── Social Proof Bar (single product) ──────────────────────── */ .sc-single-product__social-proof { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin: 10px 0 18px; } .sc-sp-enrolled { display: inline-flex; align-items: center; gap: 5px; font-size: 0.8rem; color: var(--sc-text-muted); font-weight: 500; } /* ─── Instructor Block ────────────────────────────────────────── */ .sc-instructor { display: flex; align-items: flex-start; gap: 14px; margin: 24px 0; padding: 16px; background: var(--sc-surface-alt); border-radius: var(--sc-radius-md); border: 1px solid var(--sc-border); } .sc-instructor__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--sc-accent); color: #fff; font-family: 'Manrope', sans-serif; font-weight: 800; font-size: 1.2rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; } .sc-instructor__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; } .sc-instructor__label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sc-text-muted); } .sc-instructor__name { font-size: 0.92rem; font-weight: 700; color: var(--sc-text); } .sc-instructor__bio { font-size: 0.8rem; color: var(--sc-text-muted); margin: 4px 0 0; line-height: 1.5; } /* ─── Support cards — SVG icon variant ───────────────────────── */ .sc-single-product__support-card { display: grid; grid-template-columns: 24px 1fr; grid-template-rows: auto auto; column-gap: 10px; align-items: start; } .sc-support-icon { grid-row: 1 / 3; color: var(--sc-highlight-deep); margin-top: 2px; } .sc-single-product__support-card .sc-single-product__support-label { grid-column: 2; } .sc-single-product__support-card strong { grid-column: 2; } /* ─── Sticky CTA Bar ──────────────────────────────────────────── */ .sc-sticky-cta { position: fixed; bottom: 0; left: 0; right: 0; z-index: 999; background: var(--sc-accent); color: #fff; padding: 12px 20px; transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); box-shadow: 0 -4px 24px rgba(0,0,0,0.2); } .sc-sticky-cta.is-visible { transform: translateY(0); } @media (prefers-reduced-motion: reduce) { .sc-sticky-cta { transition: none; } } .sc-sticky-cta__inner { max-width: 960px; margin: 0 auto; display: flex; align-items: center; gap: 16px; justify-content: space-between; } .sc-sticky-cta__title { font-size: 0.88rem; font-weight: 600; color: rgba(255,255,255,0.85); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .sc-sticky-cta__price { font-family: 'Manrope', sans-serif; font-weight: 800; color: var(--sc-highlight); font-size: 1rem; flex-shrink: 0; } .sc-sticky-cta .single_add_to_cart_button { padding: 10px 24px !important; font-size: 0.85rem !important; border-radius: var(--sc-radius-sm) !important; background: var(--sc-highlight) !important; color: var(--sc-accent) !important; border: none !important; font-weight: 700 !important; flex-shrink: 0; } /* ─── Mentor & Feedback Sections ──────────────────────────────── */ .sc-mentors-section { margin-top: 64px; padding: 48px 0; border-top: 1px solid var(--sc-border); } .sc-mentor-card { display: flex; flex-direction: column; height: 100%; transition: transform var(--sc-transition), box-shadow var(--sc-transition); } .sc-mentor-card:hover { transform: translateY(-4px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08) !important; } .sc-mentor-header img { border: 3px solid #ffffff; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05); } .sc-mentor-feedbacks { background: var(--sc-surface-alt); margin: 20px -24px -24px; padding: 24px; border-radius: 0 0 20px 20px; } .sc-feedback-mini { background: #ffffff; padding: 14px; border-radius: 12px; border: 1px solid rgba(197, 198, 208, 0.4); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02); } .sc-feedback-mini p { font-family: 'Work Sans', sans-serif; color: var(--sc-text); } /* Shop specific mentor section */ .sc-shop-mentors { margin: 56px 0; padding: 64px 32px; background: var(--sc-accent); color: #ffffff; border-radius: var(--sc-radius-xl); } .sc-shop-mentors h2 { color: #ffffff; text-align: center; font-size: 2.2rem; margin-bottom: 40px; }