/* Online-SPSS Theme - professional, lightweight front-end */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    background: var(--ospss-bg, #F7FAFC);
    color: var(--ospss-text, #253041);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 16px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; }
a { color: var(--ospss-secondary, #2563EB); text-decoration: none; }
a:hover { color: var(--ospss-primary, #0F2A44); }
h1, h2, h3, h4, h5, h6 {
    color: var(--ospss-primary, #0F2A44);
    line-height: 1.15;
    margin: 0 0 .85rem;
    letter-spacing: -.025em;
}
h1 { font-size: clamp(2.35rem, 4vw, 4.6rem); }
h2 { font-size: clamp(1.9rem, 3vw, 3rem); }
h3 { font-size: clamp(1.1rem, 1.6vw, 1.35rem); }
p { margin: 0 0 1rem; }
button, input, textarea, select { font: inherit; }

.ospss-container,
.container {
    width: min(1120px, calc(100% - 40px));
    margin-inline: auto;
}
.ospss-section { padding: clamp(4rem, 8vw, 7rem) 0; }
.ospss-section--compact { padding-top: clamp(3rem, 6vw, 5rem); }
.ospss-section--soft { background: #fff; }
.ospss-main { overflow: hidden; }

/* Header */
.ospss-site-header { position: sticky; top: 0; z-index: 1000; background: #fff; box-shadow: 0 12px 35px rgba(15, 42, 68, .08); }
.admin-bar .ospss-site-header { top: 32px; }
.ospss-topbar { background: var(--ospss-primary, #0F2A44); color: rgba(255,255,255,.88); font-size: .89rem; }
.ospss-topbar a { color: #fff; }
.ospss-topbar__inner { display: flex; justify-content: space-between; gap: 1rem; padding: .5rem 0; }
.ospss-topbar__left,
.ospss-topbar__right { display: flex; flex-wrap: wrap; gap: .85rem 1.15rem; align-items: center; }
.ospss-topbar__left span:not(:first-child)::before { content: "•"; margin-right: .85rem; color: var(--ospss-accent, #0EA5A4); }
.ospss-navbar__inner { min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.ospss-brand,
.ospss-footer-logo { display: inline-flex; align-items: center; gap: .65rem; color: var(--ospss-primary, #0F2A44); font-weight: 800; font-size: 1.18rem; }
.ospss-brand img,
.ospss-footer-logo img { max-height: 56px; width: auto; object-fit: contain; }
.ospss-brand__mark { display: grid; place-items: center; width: 44px; height: 44px; border-radius: 14px; background: linear-gradient(135deg, var(--ospss-secondary, #2563EB), var(--ospss-accent, #0EA5A4)); color: #fff; letter-spacing: -.05em; }
.ospss-brand__text strong { color: var(--ospss-secondary, #2563EB); }
.ospss-primary-nav { display: flex; align-items: center; }
.ospss-menu { list-style: none; display: flex; align-items: center; gap: .2rem; margin: 0; padding: 0; }
.ospss-menu li { position: relative; margin: 0; }
.ospss-menu > li > a { display: block; padding: .7rem .8rem; color: var(--ospss-primary, #0F2A44); font-weight: 700; font-size: .95rem; border-radius: 999px; }
.ospss-menu > li > a:hover,
.ospss-menu > li.current-menu-item > a { background: rgba(37, 99, 235, .09); color: var(--ospss-secondary, #2563EB); }
.ospss-menu .sub-menu { position: absolute; top: 100%; left: 0; min-width: 230px; list-style: none; margin: 0; padding: .75rem; background: #fff; border-radius: 18px; box-shadow: 0 20px 50px rgba(15, 42, 68, .13); opacity: 0; visibility: hidden; transform: translateY(10px); transition: .18s ease; }
.ospss-menu li:hover > .sub-menu,
.ospss-menu li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.ospss-menu .sub-menu a { display: block; padding: .55rem .7rem; color: var(--ospss-text, #253041); border-radius: 10px; font-weight: 650; }
.ospss-menu .sub-menu a:hover { background: rgba(14, 165, 164, .10); color: var(--ospss-primary, #0F2A44); }
.ospss-header-actions { display: flex; align-items: center; gap: .65rem; }
.ospss-link-btn { color: var(--ospss-primary, #0F2A44); font-weight: 800; font-size: .92rem; white-space: nowrap; }
.ospss-link-btn--ghost { padding: .65rem .95rem; border: 1px solid rgba(15, 42, 68, .14); border-radius: 999px; }
.ospss-menu-toggle { display: none; border: 0; background: transparent; padding: .5rem; cursor: pointer; }
.ospss-menu-toggle span:not(.screen-reader-text) { display: block; width: 26px; height: 2px; margin: 5px 0; background: var(--ospss-primary, #0F2A44); border-radius: 999px; transition: .18s ease; }
.ospss-menu-toggle[aria-expanded="true"] span:nth-child(2) { transform: translateY(7px) rotate(45deg); }
.ospss-menu-toggle[aria-expanded="true"] span:nth-child(3) { opacity: 0; }
.ospss-menu-toggle[aria-expanded="true"] span:nth-child(4) { transform: translateY(-7px) rotate(-45deg); }

/* Buttons */
.ospss-actions { display: flex; flex-wrap: wrap; gap: .8rem; align-items: center; margin: 1.7rem 0 1.2rem; }
.ospss-btn,
.wp-block-button__link,
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5rem;
    min-height: 48px;
    padding: .85rem 1.2rem;
    border-radius: 999px;
    border: 2px solid transparent;
    background: var(--ospss-warning, #F59E0B);
    color: #172033 !important;
    font-weight: 850;
    line-height: 1;
    box-shadow: 0 12px 28px rgba(245, 158, 11, .23);
    transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
}
.ospss-btn:hover,
.wp-block-button__link:hover,
.btn:hover { transform: translateY(-2px); box-shadow: 0 16px 34px rgba(245, 158, 11, .28); color: #172033 !important; }
.ospss-btn--outline { background: transparent; color: var(--ospss-primary, #0F2A44) !important; border-color: rgba(15, 42, 68, .18); box-shadow: none; }
.ospss-btn--outline:hover { background: #fff; box-shadow: 0 12px 28px rgba(15, 42, 68, .12); }
.ospss-btn--small { min-height: 42px; padding: .7rem 1rem; font-size: .92rem; }
.ospss-btn--light { background: #fff; color: var(--ospss-primary, #0F2A44) !important; box-shadow: 0 12px 34px rgba(0,0,0,.14); }

/* Hero */
.ospss-hero { position: relative; padding: clamp(4.5rem, 8vw, 8rem) 0; background:
    radial-gradient(circle at 78% 20%, rgba(14,165,164,.16), transparent 30%),
    radial-gradient(circle at 20% 20%, rgba(37,99,235,.16), transparent 32%),
    linear-gradient(135deg, #ffffff 0%, var(--ospss-bg, #F7FAFC) 52%, #eef7ff 100%);
}
.ospss-hero::after { content: ""; position: absolute; inset: auto -10% -30% auto; width: 420px; height: 420px; background: rgba(245,158,11,.16); filter: blur(80px); border-radius: 999px; pointer-events: none; }
.ospss-hero__grid { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(340px, .95fr); gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.ospss-eyebrow { display: inline-flex; align-items: center; gap: .45rem; margin-bottom: .85rem; padding: .4rem .75rem; border-radius: 999px; background: rgba(14,165,164,.12); color: var(--ospss-primary, #0F2A44); font-weight: 850; font-size: .82rem; text-transform: uppercase; letter-spacing: .07em; }
.ospss-eyebrow::before { content: ""; width: .55rem; height: .55rem; border-radius: 99px; background: var(--ospss-accent, #0EA5A4); }
.ospss-hero__lead { font-size: clamp(1.1rem, 1.8vw, 1.28rem); color: #42516a; max-width: 62ch; }
.ospss-trust-list { list-style: none; margin: 1rem 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: .65rem; }
.ospss-trust-list li { padding: .55rem .8rem; border-radius: 999px; background: #fff; border: 1px solid rgba(15,42,68,.09); color: var(--ospss-primary, #0F2A44); font-weight: 750; font-size: .9rem; box-shadow: 0 8px 18px rgba(15,42,68,.06); }
.ospss-hero__visual img { width: 100%; border-radius: 32px; box-shadow: 0 32px 80px rgba(15,42,68,.18); }
.ospss-data-card { position: relative; padding: 1.1rem; border-radius: 34px; background: rgba(255,255,255,.78); backdrop-filter: blur(14px); border: 1px solid rgba(15,42,68,.08); box-shadow: 0 34px 80px rgba(15,42,68,.18); transform: rotate(1deg); }
.ospss-data-card::before { content: "SPSS OUTPUT"; position: absolute; right: 1.4rem; top: -1.05rem; background: var(--ospss-secondary, #2563EB); color: #fff; border-radius: 999px; padding: .45rem .75rem; font-size: .75rem; font-weight: 850; letter-spacing: .06em; }
.ospss-data-card__header { display: flex; gap: .4rem; padding: .3rem .3rem 1rem; }
.ospss-data-card__header span { width: 12px; height: 12px; border-radius: 99px; background: rgba(15,42,68,.18); }
.ospss-data-card__body { min-height: 380px; border-radius: 24px; background: linear-gradient(180deg, #f8fbff, #fff); padding: clamp(1.2rem, 3vw, 2rem); }
.ospss-chart-bars { display: flex; align-items: end; gap: .8rem; height: 160px; padding: 1rem; border-radius: 22px; background: rgba(37,99,235,.07); }
.ospss-chart-bars span { display: block; flex: 1; border-radius: 999px 999px 8px 8px; background: linear-gradient(180deg, var(--ospss-accent, #0EA5A4), var(--ospss-secondary, #2563EB)); }
.ospss-chart-bars span:nth-child(1) { height: 42%; }
.ospss-chart-bars span:nth-child(2) { height: 70%; }
.ospss-chart-bars span:nth-child(3) { height: 54%; }
.ospss-chart-bars span:nth-child(4) { height: 86%; }
.ospss-chart-bars span:nth-child(5) { height: 62%; }
.ospss-output-lines { display: grid; gap: .85rem; margin: 1.7rem 0; }
.ospss-output-lines span { height: 13px; border-radius: 999px; background: rgba(15,42,68,.12); }
.ospss-output-lines span:nth-child(2) { width: 78%; }
.ospss-output-lines span:nth-child(3) { width: 88%; }
.ospss-output-lines span:nth-child(4) { width: 64%; }
.ospss-mini-result { padding: .9rem 1rem; border-radius: 16px; background: #ecfdfb; color: #0f766e; font-weight: 850; }

/* Cards and sections */
.ospss-section-heading { max-width: 760px; margin: 0 auto 2.3rem; text-align: center; }
.ospss-section-heading p { color: #59677d; font-size: 1.05rem; }
.ospss-card-grid { display: grid; gap: 1.2rem; }
.ospss-card-grid--four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.ospss-card-grid--three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.ospss-card,
.ospss-service-card,
.ospss-post-card,
.ospss-step,
.ospss-stats-card,
.ospss-insight-panel {
    background: #fff;
    border: 1px solid rgba(15,42,68,.08);
    border-radius: 24px;
    padding: clamp(1.25rem, 2.3vw, 1.75rem);
    box-shadow: 0 18px 45px rgba(15,42,68,.07);
}
.ospss-card { transition: transform .16s ease, box-shadow .16s ease; }
.ospss-card:hover,
.ospss-service-card:hover,
.ospss-post-card:hover { transform: translateY(-4px); box-shadow: 0 24px 54px rgba(15,42,68,.10); }
.ospss-card__icon { width: 48px; height: 48px; display: grid; place-items: center; margin-bottom: 1rem; border-radius: 16px; background: linear-gradient(135deg, rgba(37,99,235,.12), rgba(14,165,164,.16)); color: var(--ospss-primary, #0F2A44); font-weight: 900; }
.ospss-service-card { position: relative; overflow: hidden; }
.ospss-service-card::after { content: ""; position: absolute; inset: auto 1.25rem 0; height: 4px; border-radius: 999px 999px 0 0; background: linear-gradient(90deg, var(--ospss-secondary, #2563EB), var(--ospss-accent, #0EA5A4)); opacity: .85; }
.ospss-split { display: grid; grid-template-columns: minmax(0, .95fr) minmax(320px, 1.05fr); gap: clamp(2rem, 5vw, 5rem); align-items: center; }
.ospss-split--reverse { grid-template-columns: minmax(320px, .95fr) minmax(0, 1.05fr); }
.ospss-split__media img { width: 100%; border-radius: 30px; box-shadow: 0 28px 70px rgba(15,42,68,.15); }
.ospss-check-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem; margin-top: 1.2rem; }
.ospss-check-grid span,
.ospss-tick-list li { position: relative; padding-left: 1.75rem; color: var(--ospss-primary, #0F2A44); font-weight: 750; }
.ospss-check-grid span::before,
.ospss-tick-list li::before { content: "✓"; position: absolute; left: 0; top: 0; display: grid; place-items: center; width: 1.15rem; height: 1.15rem; border-radius: 99px; background: rgba(14,165,164,.14); color: var(--ospss-accent, #0EA5A4); font-size: .78rem; font-weight: 900; }
.ospss-insight-panel { background: linear-gradient(135deg, var(--ospss-primary, #0F2A44), #143a5d); color: rgba(255,255,255,.85); padding: clamp(2rem, 5vw, 3rem); }
.ospss-insight-panel strong { display: block; color: #fff; font-size: clamp(1.5rem, 2.5vw, 2.25rem); line-height: 1.15; margin-bottom: 1rem; }
.ospss-steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.2rem; counter-reset: ospss-step; }
.ospss-step span { display: grid; place-items: center; width: 54px; height: 54px; border-radius: 18px; background: var(--ospss-primary, #0F2A44); color: #fff; font-weight: 900; font-size: 1.25rem; margin-bottom: 1rem; }
.ospss-why { background: linear-gradient(180deg, #fff, var(--ospss-bg, #F7FAFC)); }
.ospss-tick-list { list-style: none; padding: 0; margin: 1.25rem 0 0; display: grid; gap: .8rem; }
.ospss-stats-card { background: var(--ospss-primary, #0F2A44); color: rgba(255,255,255,.86); }
.ospss-stats-card h3 { color: #fff; }
.ospss-stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; margin-top: 1.4rem; }
.ospss-stat-grid div { padding: 1rem; border-radius: 18px; background: rgba(255,255,255,.08); }
.ospss-stat-grid strong { display: block; color: #fff; font-size: clamp(1.35rem, 2vw, 1.9rem); line-height: 1; margin-bottom: .45rem; }
.ospss-stat-grid span { display: block; font-size: .86rem; color: rgba(255,255,255,.75); }
.ospss-post-card { padding: 0; overflow: hidden; }
.ospss-post-card img { display: block; width: 100%; aspect-ratio: 16/10; object-fit: cover; }
.ospss-post-card h3,
.ospss-post-card p { padding-inline: 1.25rem; }
.ospss-post-card h3 { margin-top: 1.25rem; }
.ospss-post-card p { padding-bottom: 1.25rem; color: #59677d; }

/* FAQ and CTA */
.ospss-faq-list { max-width: 860px; margin: 0 auto; display: grid; gap: .85rem; }
.ospss-faq { background: #fff; border: 1px solid rgba(15,42,68,.09); border-radius: 18px; box-shadow: 0 12px 28px rgba(15,42,68,.05); overflow: hidden; }
.ospss-faq summary { cursor: pointer; padding: 1.15rem 1.25rem; color: var(--ospss-primary, #0F2A44); font-weight: 850; }
.ospss-faq p { padding: 0 1.25rem 1.2rem; color: #59677d; }
.ospss-cta { padding: clamp(3rem, 6vw, 5rem) 0; background: linear-gradient(135deg, var(--ospss-primary, #0F2A44), #153d61); color: rgba(255,255,255,.86); }
.ospss-cta h2 { color: #fff; }
.ospss-cta .ospss-eyebrow { background: rgba(255,255,255,.11); color: #fff; }
.ospss-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.ospss-cta__inner div { max-width: 760px; }

/* Footer */
.ospss-footer { background: #081a2c; color: rgba(255,255,255,.78); }
.ospss-footer a { color: rgba(255,255,255,.9); }
.ospss-footer a:hover { color: #fff; }
.ospss-footer__grid { display: grid; grid-template-columns: minmax(280px, 1.35fr) repeat(3, minmax(0, .8fr)); gap: clamp(1.5rem, 4vw, 3rem); padding: clamp(3rem, 6vw, 5rem) 0; }
.ospss-footer h2 { color: #fff; font-size: 1.05rem; margin-bottom: 1rem; }
.ospss-footer-logo { color: #fff; margin-bottom: 1rem; }
.ospss-footer-logo .ospss-brand__text { color: #fff; }
.ospss-footer__socials { display: flex; flex-wrap: wrap; gap: .6rem; margin-top: 1rem; }
.ospss-footer__socials a { display: inline-flex; align-items: center; justify-content: center; min-height: 34px; padding: .35rem .7rem; border-radius: 999px; background: rgba(255,255,255,.08); font-size: .9rem; }
.ospss-footer-menu,
.ospss-policy-menu { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
.ospss-footer__contact p { margin-bottom: .65rem; }
.ospss-footer__bottom { border-top: 1px solid rgba(255,255,255,.09); }
.ospss-footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 0; font-size: .92rem; }
.ospss-policy-menu { display: flex; flex-wrap: wrap; gap: .9rem; }

/* WordPress content defaults */
.entry-content,
.post-content,
.ospss-content { max-width: 780px; margin-inline: auto; }
article.post,
article.page { padding: 3rem 0; }
.wp-block-image img { border-radius: 18px; }
.wp-caption { max-width: 100%; }
input[type="text"], input[type="email"], input[type="url"], input[type="search"], input[type="tel"], textarea, select {
    width: 100%; padding: .85rem 1rem; border: 1px solid rgba(15,42,68,.14); border-radius: 14px; background: #fff; color: var(--ospss-text, #253041); outline: 0;
}
input:focus, textarea:focus, select:focus { border-color: var(--ospss-secondary, #2563EB); box-shadow: 0 0 0 4px rgba(37,99,235,.12); }
input[type="submit"], button[type="submit"] { cursor: pointer; }
.screen-reader-text { clip: rect(1px,1px,1px,1px); position: absolute !important; height: 1px; width: 1px; overflow: hidden; }
.screen-reader-text:focus { clip: auto !important; width: auto; height: auto; z-index: 99999; background: #fff; color: var(--ospss-primary, #0F2A44); padding: .75rem 1rem; left: 1rem; top: 1rem; border-radius: 10px; box-shadow: 0 8px 20px rgba(0,0,0,.15); }

/* Minimal compatibility with older Bootstrap-style templates */
.row { display: flex; flex-wrap: wrap; gap: 1.5rem; }
.col-lg-8 { flex: 1 1 620px; }
.col-lg-4 { flex: 1 1 300px; }
.img-fluid { max-width: 100%; height: auto; }
.rounded { border-radius: 18px; }
.text-primary { color: var(--ospss-primary, #0F2A44) !important; }
.text-secondary { color: #59677d !important; }
.bg-primary { background: var(--ospss-primary, #0F2A44) !important; }
.text-white { color: #fff !important; }

@media (max-width: 1080px) {
    .ospss-header-actions { display: none; }
    .ospss-card-grid--four { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
    .admin-bar .ospss-site-header { top: 46px; }
    .ospss-container,
    .container { width: min(100% - 28px, 1120px); }
    .ospss-topbar { display: none; }
    .ospss-navbar__inner { min-height: 68px; }
    .ospss-menu-toggle { display: block; margin-left: auto; }
    .ospss-primary-nav { position: absolute; left: 14px; right: 14px; top: calc(100% + 10px); display: block; max-height: min(75vh, 560px); overflow: auto; background: #fff; border: 1px solid rgba(15,42,68,.10); border-radius: 22px; box-shadow: 0 22px 50px rgba(15,42,68,.16); padding: .85rem; opacity: 0; visibility: hidden; transform: translateY(-8px); transition: .18s ease; }
    .ospss-primary-nav.is-open { opacity: 1; visibility: visible; transform: translateY(0); }
    .ospss-menu { display: grid; gap: .15rem; }
    .ospss-menu > li > a { border-radius: 12px; padding: .8rem .9rem; }
    .ospss-menu .sub-menu { position: static; min-width: 0; box-shadow: none; border: 0; padding: .25rem 0 .35rem 1rem; opacity: 1; visibility: visible; transform: none; display: block; }
    .ospss-hero__grid,
    .ospss-split,
    .ospss-split--reverse { grid-template-columns: 1fr; }
    .ospss-hero__visual { order: -1; }
    .ospss-data-card { transform: none; }
    .ospss-data-card__body { min-height: 260px; }
    .ospss-card-grid--three,
    .ospss-steps { grid-template-columns: 1fr; }
    .ospss-cta__inner,
    .ospss-footer__bottom-inner { align-items: flex-start; flex-direction: column; }
    .ospss-footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px) {
    h1 { font-size: clamp(2rem, 12vw, 2.8rem); }
    .ospss-card-grid--four,
    .ospss-check-grid,
    .ospss-stat-grid,
    .ospss-footer__grid { grid-template-columns: 1fr; }
    .ospss-actions { align-items: stretch; }
    .ospss-actions .ospss-btn { width: 100%; }
}
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}
.ospss-card-grid--two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 860px) { .ospss-card-grid--two { grid-template-columns: 1fr; } }
.ospss-search-form { display: flex; gap: .65rem; align-items: center; max-width: 620px; margin: 1rem auto 0; }
.ospss-search-form input[type="search"] { min-height: 48px; }
@media (max-width: 620px) { .ospss-search-form { flex-direction: column; align-items: stretch; } }

/* Refinements: reviews, readable pages, blog archives, and analysts */
.ospss-section-action { margin-top: 2rem; text-align: center; }
.ospss-text-link { display: inline-flex; align-items: center; gap: .35rem; color: var(--ospss-secondary, #2563EB); font-weight: 850; }
.ospss-text-link::after { content: "→"; transition: transform .16s ease; }
.ospss-text-link:hover::after { transform: translateX(3px); }
.ospss-archive-hero,
.ospss-page-hero { padding: clamp(3rem, 6vw, 5rem) 0; }
.ospss-archive-hero h1,
.ospss-page-hero h1 { font-size: clamp(2rem, 3.2vw, 3.25rem); max-width: 920px; margin-inline: auto; }
.ospss-archive-hero .ospss-section-heading,
.ospss-page-hero .ospss-section-heading { margin-bottom: 0; }
.ospss-blog-listing { padding-top: clamp(3rem, 6vw, 4.5rem); }
.ospss-blog-card__body { padding: 1.25rem; }
.ospss-blog-card__body > span { display: inline-block; margin-bottom: .55rem; color: #6a778b; font-weight: 750; font-size: .88rem; }
.ospss-blog-card h2 { font-size: clamp(1.1rem, 1.5vw, 1.35rem); line-height: 1.25; margin-bottom: .75rem; }
.ospss-blog-card h2 a { color: var(--ospss-primary, #0F2A44); }
.ospss-blog-card h2 a:hover { color: var(--ospss-secondary, #2563EB); }
.ospss-blog-card p { padding: 0; margin-bottom: 1rem; }
.ospss-pagination { margin-top: 2rem; }
.ospss-pagination .nav-links { display: flex; flex-wrap: wrap; gap: .55rem; justify-content: center; }
.ospss-pagination .page-numbers { min-width: 40px; min-height: 40px; display: inline-flex; align-items: center; justify-content: center; padding: .4rem .75rem; border: 1px solid rgba(15,42,68,.12); border-radius: 999px; background: #fff; color: var(--ospss-primary, #0F2A44); font-weight: 800; }
.ospss-pagination .current { background: var(--ospss-primary, #0F2A44); color: #fff; }

.ospss-page-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, 340px); gap: clamp(1.5rem, 4vw, 3rem); align-items: start; }
.ospss-readable-content { max-width: none; background: #fff; border: 1px solid rgba(15,42,68,.08); border-radius: 26px; padding: clamp(1.4rem, 3.5vw, 2.6rem); box-shadow: 0 18px 45px rgba(15,42,68,.06); }
.ospss-readable-content > *:first-child { margin-top: 0; }
.ospss-readable-content h2 { font-size: clamp(1.45rem, 2.2vw, 2rem); margin-top: 2rem; }
.ospss-readable-content h3 { font-size: clamp(1.15rem, 1.7vw, 1.35rem); margin-top: 1.6rem; }
.ospss-readable-content ul,
.ospss-readable-content ol { padding-left: 1.25rem; }
.ospss-readable-content li { margin-bottom: .45rem; }
.ospss-content-centered { max-width: 860px; }
.ospss-content-wide { max-width: 1120px; }
.ospss-page-sidebar { display: grid; gap: 1rem; position: sticky; top: 118px; }
.ospss-sidebar-card { background: #fff; border: 1px solid rgba(15,42,68,.08); border-radius: 24px; padding: 1.2rem; box-shadow: 0 18px 42px rgba(15,42,68,.07); }
.ospss-sidebar-card .ospss-eyebrow { font-size: .72rem; margin-bottom: .75rem; }
.ospss-sidebar-card .ospss-btn { width: 100%; margin-top: .85rem; }
.ospss-sidebar-list { list-style: none; padding: 0; margin: .25rem 0 .5rem; display: grid; gap: .65rem; }
.ospss-sidebar-list li { position: relative; padding-left: 1.55rem; font-weight: 720; color: var(--ospss-primary, #0F2A44); }
.ospss-sidebar-list li::before { content: "✓"; position: absolute; left: 0; top: .05rem; color: var(--ospss-accent, #0EA5A4); font-weight: 900; }

.ospss-stars { display: flex; align-items: center; gap: .16rem; margin-bottom: .95rem; color: #c7d0df; }
.ospss-stars span { font-size: 1.05rem; line-height: 1; }
.ospss-stars .is-filled { color: var(--ospss-warning, #F59E0B); }
.ospss-stars strong { margin-left: .45rem; color: var(--ospss-primary, #0F2A44); font-size: .92rem; }
.ospss-review-carousel { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(300px, 380px); gap: 1rem; overflow-x: auto; padding: .35rem .15rem 1rem; scroll-snap-type: x proximity; scrollbar-width: thin; }
.ospss-review-card { scroll-snap-align: start; background: #fff; border: 1px solid rgba(15,42,68,.08); border-radius: 24px; padding: 1.35rem; box-shadow: 0 18px 42px rgba(15,42,68,.07); }
.ospss-review-card h3 { font-size: 1.08rem; margin-bottom: .6rem; }
.ospss-review-card p { color: #536176; margin-bottom: 1rem; }
.ospss-review-card > span { display: inline-flex; align-items: center; padding: .35rem .65rem; border-radius: 999px; background: rgba(37,99,235,.08); color: var(--ospss-primary, #0F2A44); font-weight: 800; font-size: .86rem; }
.ospss-review-card--compact { padding: 0; border: 0; box-shadow: none; background: transparent; }
.ospss-review-card--compact h3 { font-size: 1rem; }
.ospss-review-card--compact p { font-size: .94rem; }
.ospss-review-summary { display: flex; align-items: center; justify-content: space-between; gap: 1.4rem; padding: clamp(1.25rem, 3vw, 2rem); margin-bottom: 1.4rem; border-radius: 26px; background: linear-gradient(135deg, #fff, #f3fbff); border: 1px solid rgba(15,42,68,.08); box-shadow: 0 18px 45px rgba(15,42,68,.06); }
.ospss-review-summary h2 { font-size: clamp(1.35rem, 2vw, 1.8rem); margin-bottom: .5rem; }
.ospss-review-summary p { margin-bottom: 0; color: #59677d; }
.ospss-review-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1rem; }

.ospss-writer-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 1.2rem; }
.ospss-writer-card { background: #fff; border: 1px solid rgba(15,42,68,.08); border-radius: 26px; padding: 1.25rem; box-shadow: 0 18px 45px rgba(15,42,68,.07); transition: transform .16s ease, box-shadow .16s ease; }
.ospss-writer-card:hover { transform: translateY(-4px); box-shadow: 0 24px 54px rgba(15,42,68,.1); }
.ospss-writer-card__image { width: 132px; height: 132px; display: grid; place-items: center; margin: 0 auto 1.15rem; border-radius: 50%; overflow: hidden; background: linear-gradient(135deg, rgba(37,99,235,.13), rgba(14,165,164,.16)); color: var(--ospss-primary, #0F2A44); font-size: 2.5rem; font-weight: 900; }
.ospss-writer-card__image img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.ospss-writer-card__body { text-align: center; }
.ospss-writer-card__body .ospss-eyebrow { font-size: .7rem; }
.ospss-writer-card h2 { font-size: 1.25rem; margin-bottom: .65rem; }
.ospss-writer-card h2 a { color: var(--ospss-primary, #0F2A44); }
.ospss-writer-card p { color: #59677d; }
.ospss-writer-meta { display: flex; flex-wrap: wrap; gap: .45rem; justify-content: center; margin: .85rem 0 1rem; }
.ospss-writer-meta span { padding: .35rem .6rem; border-radius: 999px; background: rgba(14,165,164,.10); color: var(--ospss-primary, #0F2A44); font-weight: 800; font-size: .84rem; }
.ospss-writer-profile { display: grid; grid-template-columns: minmax(220px, 320px) minmax(0, 1fr); gap: clamp(1.5rem, 4vw, 3rem); align-items: center; }
.ospss-writer-profile__image { width: min(320px, 100%); aspect-ratio: 1; display: grid; place-items: center; border-radius: 50%; overflow: hidden; background: linear-gradient(135deg, rgba(37,99,235,.13), rgba(14,165,164,.16)); color: var(--ospss-primary, #0F2A44); font-size: 4rem; font-weight: 900; box-shadow: 0 24px 60px rgba(15,42,68,.13); }
.ospss-writer-profile__image img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.ospss-writer-profile h1 { font-size: clamp(2rem, 3.4vw, 3.6rem); }
.ospss-writer-profile__stats { display: flex; flex-wrap: wrap; gap: .75rem; margin: 1.2rem 0 1.5rem; }
.ospss-writer-profile__stats div { min-width: 128px; padding: .85rem 1rem; border-radius: 18px; background: #fff; border: 1px solid rgba(15,42,68,.08); box-shadow: 0 10px 25px rgba(15,42,68,.05); }
.ospss-writer-profile__stats strong { display: block; color: var(--ospss-primary, #0F2A44); font-size: 1.2rem; line-height: 1; margin-bottom: .35rem; }
.ospss-writer-profile__stats span { display: block; color: #59677d; font-size: .85rem; font-weight: 760; }
.ospss-footer-cta { margin-top: .75rem; }
.ospss-brand .custom-logo,
.ospss-footer-logo .custom-logo { max-height: 56px; width: auto; object-fit: contain; }

@media (max-width: 1020px) {
    .ospss-page-layout { grid-template-columns: 1fr; }
    .ospss-page-sidebar { position: static; grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .ospss-review-grid,
    .ospss-writer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
    .ospss-page-sidebar,
    .ospss-review-grid,
    .ospss-writer-grid,
    .ospss-writer-profile { grid-template-columns: 1fr; }
    .ospss-review-summary { flex-direction: column; align-items: flex-start; }
    .ospss-review-summary .ospss-btn { width: 100%; }
    .ospss-review-carousel { grid-auto-columns: minmax(260px, 88vw); }
}
