/* on-topic.com overrides: Hero + content boxes + Angebot cards */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@500;600;700&display=swap');

:root {
    --ot-hero-panel: linear-gradient(138deg, rgba(7, 32, 52, 0.82) 0%, rgba(9, 52, 78, 0.76) 74%);
    --ot-card-surface: #ffffff;
    --ot-card-surface-soft: #f7fafd;
    --ot-card-line: #d3dfed;
    --ot-card-shadow: 0 14px 34px rgba(15, 44, 72, 0.11);
    --ot-card-shadow-strong: 0 18px 42px rgba(12, 35, 58, 0.16);
    --ot-accent: #f84f2b;
    --ot-accent-strong: #e84522;
    --ot-focus: #0f334d;
    --ot-brand-blue: #2373b5;
    --ot-brand-blue-dark: #1c5b8f;
}

/* Global: section spacing kompakter (seitenuebergreifend) */
.entry-content .section,
.about-intro,
.values-section,
.services-section,
.cta-section,
.contact-section,
.products-section,
.products-faq {
    padding-bottom: clamp(1.25rem, 2.4vw, 2rem) !important;
}

.entry-content .section-subtitle,
.cta-section p {
    margin-bottom: clamp(0.6rem, 1.8vw, 1.1rem) !important;
}

.services-grid,
.products-grid {
    margin-bottom: clamp(0.8rem, 1.8vw, 1.4rem) !important;
}

.entry-content .section-cta,
.section-cta,
.cta-section {
    margin-top: clamp(0.4rem, 1.1vw, 0.9rem) !important;
}

.entry-content .container > p:empty {
    display: none !important;
}

/* Startseite Hero: Editorial Look aus Variante B (nur benoetigte Teile) */
.hero-fullwidth {
    position: relative;
    min-height: clamp(440px, 68vh, 760px) !important;
    display: flex;
    align-items: stretch;
    background-size: cover !important;
    background-position: center !important;
    overflow: hidden;
    padding: 0 !important;
}

.hero-fullwidth::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(95deg, rgba(11, 42, 58, 0.88) 0%, rgba(11, 42, 58, 0.65) 50%, rgba(11, 42, 58, 0.3) 100%);
    z-index: 1;
}

.hero-fullwidth::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -1px;
    width: 35%;
    height: 30%;
    background: #f4f7fb;
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
    z-index: 2;
    pointer-events: none;
}

.hero-overlay {
    display: none !important;
}

.hero-content {
    position: relative;
    z-index: 3;
    width: 100%;
    max-width: var(--container-max);
    margin: 0 auto;
    padding: clamp(2rem, 6vw, 4.2rem) clamp(1rem, 4vw, 2rem) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    text-align: left !important;
    align-self: center;
}

.hero-tagline {
    display: inline-flex;
    align-items: center;
    gap: 0.6rem;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--ot-accent);
    margin-bottom: 1rem;
}

.hero-tagline::before {
    content: "";
    width: 30px;
    height: 2px;
    background: currentColor;
}

.hero-fullwidth h1 {
    font-family: 'Cormorant Garamond', 'Sora', 'Times New Roman', serif !important;
    font-size: clamp(2.75rem, 7vw, 5.3rem) !important;
    font-weight: 600 !important;
    line-height: 0.95;
    letter-spacing: 0;
    margin-bottom: 1rem;
    max-width: 16ch;
    color: #ffffff;
    text-shadow: none;
}

.hero-fullwidth h1 em,
.hero-fullwidth h1 .accent {
    color: var(--ot-accent);
    font-style: italic;
    font-weight: 600;
}

.hero-fullwidth .hero-subtitle {
    font-size: clamp(1.1rem, 1.8vw, 1.35rem) !important;
    line-height: 1.45;
    margin-bottom: 0.55rem;
    color: rgba(255, 255, 255, 0.92) !important;
    max-width: 48ch;
}

.hero-description {
    font-size: 1.05rem !important;
    line-height: 1.62;
    color: rgba(255, 255, 255, 0.8) !important;
    max-width: 48ch;
    margin-bottom: 1.4rem;
}

/* Leistungen Hero: gleiches Bild, modernere Hero-Komposition */
body.page-id-12 .page-hero,
body.page-id-30 .page-hero {
    position: relative;
    overflow: hidden;
    min-height: clamp(360px, 56vh, 620px) !important;
    padding: clamp(2.2rem, 4.8vw, 4.1rem) 0 !important;
    background-size: cover !important;
    background-position: center !important;
}

body.page-id-12 .page-hero::before,
body.page-id-30 .page-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(96deg, rgba(10, 40, 60, 0.78) 0%, rgba(11, 47, 71, 0.58) 48%, rgba(12, 58, 86, 0.34) 100%);
    z-index: 1;
}

body.page-id-12 .page-hero::after,
body.page-id-30 .page-hero::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: -1px;
    width: 30%;
    height: 24%;
    background: #f4f7fb;
    clip-path: polygon(100% 0, 100% 100%, 0 100%);
    z-index: 2;
    pointer-events: none;
}

body.page-id-12 .page-hero .hero-text-box,
body.page-id-30 .page-hero .hero-text-box {
    position: relative;
    z-index: 3;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    border-radius: 0 !important;
    max-width: var(--container-max) !important;
    margin: 0 auto !important;
    padding: 0 clamp(1rem, 4vw, 2rem) !important;
}

body.page-id-12 .page-hero .hero-text-box::before,
body.page-id-30 .page-hero .hero-text-box::before {
    content: "-- Online Marketing Success";
    display: inline-block;
    margin-bottom: 0.95rem;
    color: #f84f2b;
    font-family: 'Sora', 'Manrope', 'Segoe UI', sans-serif;
    font-size: clamp(0.72rem, 1vw, 0.9rem);
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
}

body.page-id-12 .page-hero h1,
body.page-id-30 .page-hero h1 {
    font-family: 'Cormorant Garamond', 'Sora', 'Times New Roman', serif !important;
    font-size: clamp(3rem, 7.6vw, 6rem) !important;
    font-weight: 600 !important;
    line-height: 0.92;
    letter-spacing: 0;
    margin-bottom: 0.9rem !important;
    color: #ffffff !important;
    text-shadow: none !important;
    max-width: 11.5ch;
    text-wrap: balance;
}

body.page-id-12 .page-hero h1 em,
body.page-id-30 .page-hero h1 em,
body.page-id-12 .page-hero h1 .accent,
body.page-id-30 .page-hero h1 .accent {
    color: var(--ot-accent) !important;
    font-style: italic;
    font-weight: 600;
}

body.page-id-12 .page-hero .hero-subtitle,
body.page-id-30 .page-hero .hero-subtitle {
    font-size: clamp(1.12rem, 2.1vw, 1.55rem) !important;
    line-height: 1.45;
    color: rgba(241, 248, 255, 0.93) !important;
    max-width: 40ch;
    text-wrap: balance;
}


/* GP Element Hero (opt-in via class .ot-opening-hero) */
.ot-opening-hero {
    position: relative;
    overflow: hidden;
    min-height: clamp(430px, 62vh, 680px);
    padding: clamp(36px, 5vw, 72px) clamp(18px, 4vw, 44px);
    border-radius: 18px;
    background-size: cover;
    background-position: center;
    box-shadow: 0 20px 48px rgba(8, 30, 47, 0.28);
}

.ot-opening-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(95deg, rgba(8, 36, 57, 0.8) 0%, rgba(9, 53, 78, 0.58) 56%, rgba(10, 49, 73, 0.36) 100%);
}

.ot-opening-hero .ot-opening-inner {
    position: relative;
    z-index: 1;
    max-width: min(760px, 100%);
    margin-left: clamp(8px, 7vw, 120px);
    color: #f2f8ff;
}

.ot-opening-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 0.95rem;
    color: #ff5a35;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-size: 0.82rem;
    font-weight: 700;
}

.ot-opening-kicker::before {
    content: "";
    width: 30px;
    height: 2px;
    background: currentColor;
}

.ot-opening-title {
    margin: 0 0 0.9rem;
    font-family: 'Cormorant Garamond', 'Sora', 'Times New Roman', serif;
    font-size: clamp(2.5rem, 6vw, 5rem);
    font-weight: 600;
    line-height: 0.95;
    color: #f3f9ff;
    letter-spacing: 0.01em;
}

.ot-opening-title em {
    color: #ff5a35;
    font-style: italic;
    font-weight: 600;
}

.ot-opening-text {
    margin: 0 0 1.4rem;
    font-size: clamp(1.03rem, 1.6vw, 1.24rem);
    line-height: 1.52;
    color: rgba(233, 243, 252, 0.95);
    max-width: 48ch;
}

.ot-opening-actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin: 0.5rem 0 1.2rem;
}

.ot-opening-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 230px;
    padding: 14px 22px;
    border-radius: 11px;
    font-size: 1.03rem;
    font-weight: 700;
    text-decoration: none;
    border: 1px solid transparent;
}

.ot-opening-btn-primary {
    background: linear-gradient(135deg, #f84f2b 0%, #e84522 100%);
    color: #ffffff;
}

.ot-opening-btn-secondary {
    background: rgba(10, 41, 62, 0.64);
    border-color: rgba(227, 239, 251, 0.72);
    color: #f2f8ff;
}

.ot-opening-meta {
    border-top: 1px solid rgba(214, 229, 242, 0.32);
    padding-top: 0.95rem;
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    color: rgba(229, 240, 250, 0.9);
    font-size: 0.95rem;
}

@media (max-width: 768px) {
    .ot-opening-hero {
        min-height: 360px;
        border-radius: 14px;
    }

    .ot-opening-hero .ot-opening-inner {
        margin-left: 0;
    }

    .ot-opening-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .ot-opening-btn {
        width: 100%;
        min-width: 0;
    }
}

/* Markante CTA-Box mit zwei Buttons */
.section-cta,
.cta-section .container {
    max-width: min(960px, calc(100% - 28px)) !important;
    margin: clamp(0.5rem, 1.4vw, 1rem) auto clamp(0.9rem, 1.9vw, 1.6rem) !important;
    padding: clamp(1.2rem, 2vw, 2rem) !important;
    border: 2px solid rgba(23, 90, 141, 0.42) !important;
    border-radius: 18px !important;
    background: linear-gradient(145deg, rgba(35, 115, 181, 0.16) 0%, rgba(27, 95, 151, 0.26) 100%) !important;
    box-shadow: 0 15px 38px rgba(13, 52, 84, 0.2) !important;
    text-align: center !important;
}

.section-cta h2,
.section-cta p,
.cta-section .container h2,
.cta-section .container p {
    text-align: center !important;
}

.section-cta h2,
.cta-section .container h2 {
    color: #0f3f66 !important;
    margin-bottom: 0.35rem;
}

.section-cta p,
.cta-section .container p {
    color: #2d4a64 !important;
    margin-bottom: 0.35rem;
}

.ot-cta-actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 0.35rem;
}

.ot-cta-actions .ot-cta-btn {
    min-width: 260px;
    border-radius: 12px !important;
    padding: 14px 24px !important;
    font-size: 1.02rem !important;
    font-weight: 700 !important;
    text-decoration: none !important;
}

.ot-cta-actions .ot-cta-btn-primary {
    background: linear-gradient(135deg, #f84f2b 0%, #e84522 100%) !important;
    color: #ffffff !important;
    border: 1px solid rgba(184, 59, 29, 0.6) !important;
    box-shadow: 0 8px 18px rgba(185, 66, 34, 0.28) !important;
}

.ot-cta-actions .ot-cta-btn-secondary {
    background: linear-gradient(135deg, #3e9344 0%, #2f7a37 100%) !important;
    color: #ffffff !important;
    border: 1px solid rgba(35, 102, 46, 0.72) !important;
    box-shadow: 0 8px 18px rgba(29, 89, 39, 0.24) !important;
}

.ot-cta-actions .ot-cta-btn:hover {
    transform: translateY(-1px);
}

/* Startseite Content-Boxen: moderner + ruhig */
.feature-card,
.card,
.service-card,
.value-card {
    background: linear-gradient(180deg, var(--ot-card-surface) 0%, var(--ot-card-surface-soft) 100%) !important;
    border: 1.5px solid var(--ot-card-line) !important;
    border-radius: 18px !important;
    box-shadow: var(--ot-card-shadow) !important;
}

.feature-card:hover,
.card:hover,
.service-card:hover,
.value-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--ot-card-shadow-strong) !important;
    border-color: #bfcee0 !important;
}

.feature-icon,
.card-icon,
.service-icon,
.value-icon {
    width: 52px !important;
    height: 52px !important;
    border-radius: 13px !important;
    border: 1px solid #d8e3f3 !important;
    background: #ecf4ff !important;
    color: #104f80 !important;
    box-shadow: 0 8px 16px rgba(16, 63, 103, 0.16) !important;
}

.feature-icon.orange,
.service-icon.icon-orange,
.icon-orange {
    background: #fff0ea !important;
    border-color: #ffd7ca !important;
    color: #d54a24 !important;
}

.feature-icon.teal,
.service-icon.icon-teal,
.icon-teal {
    background: #e8f8fc !important;
    border-color: #bfe8f2 !important;
    color: #1b748f !important;
}

.feature-icon.green,
.service-icon.icon-green,
.icon-green {
    background: #e9fbf1 !important;
    border-color: #c7efd8 !important;
    color: #1c8e4a !important;
}

.feature-icon.blue,
.icon-blue {
    background: #eaf3fe !important;
    border-color: #c9def8 !important;
    color: #1e65a2 !important;
}

.feature-content h4,
.service-header h3,
.value-header h3 {
    letter-spacing: -0.01em;
}

/* Angebotsseite: Card-Look wie Referenz */
.onoc-products-grid {
    gap: 28px;
    margin: 38px auto 30px;
    align-items: stretch;
}

.onoc-product-card {
    border-radius: 20px !important;
    border: 1.5px solid #2b83cc !important;
    background: #f5f3ec !important;
    box-shadow: 10px 10px 0 rgba(18, 122, 166, 0.66), 0 16px 34px rgba(11, 31, 53, 0.08) !important;
    padding: 30px 28px 24px !important;
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.onoc-product-card:hover {
    transform: translateY(-5px);
    box-shadow: 12px 12px 0 rgba(18, 122, 166, 0.68), 0 20px 40px rgba(11, 31, 53, 0.14) !important;
}

.onoc-product-card.popular {
    background-image:
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 2px, rgba(255, 255, 255, 0) 2px 18px),
        linear-gradient(165deg, var(--ot-brand-blue) 0%, var(--ot-brand-blue-dark) 74%) !important;
    border-color: #1f6299 !important;
    box-shadow: 10px 10px 0 rgba(15, 87, 146, 0.86), 0 20px 42px rgba(7, 20, 33, 0.26) !important;
}

.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) {
    background-image:
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 2px, rgba(255, 255, 255, 0) 2px 18px),
        linear-gradient(165deg, var(--ot-brand-blue) 0%, var(--ot-brand-blue-dark) 74%) !important;
    border-color: #1f6299 !important;
    box-shadow: 10px 10px 0 rgba(15, 87, 146, 0.86), 0 20px 42px rgba(7, 20, 33, 0.26) !important;
}

.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular)::before {
    content: "Beliebt";
    position: absolute;
    top: -16px;
    left: 50%;
    transform: translateX(-50%);
    padding: 9px 28px;
    border-radius: 9px;
    background: var(--ot-accent);
    color: #ffffff;
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 4px 4px 0 #2582cc;
    z-index: 2;
}

html[lang^="en"] .onoc-products-grid .onoc-product-card:nth-child(2):not(.popular)::before {
    content: "Popular";
}

.onoc-popular-badge {
    top: -16px !important;
    padding: 9px 28px !important;
    border-radius: 9px !important;
    background: var(--ot-accent) !important;
    color: #ffffff !important;
    font-size: 1.05rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.08em !important;
    box-shadow: 4px 4px 0 #2582cc;
}

.onoc-product-name {
    margin: 10px 0 12px !important;
    font-family: 'Sora', 'Manrope', 'Segoe UI', sans-serif;
    font-size: clamp(2rem, 2.8vw, 2.9rem) !important;
    line-height: 1.08;
    color: #172b44 !important;
}

.onoc-product-description {
    margin: 0 0 18px !important;
    padding-top: 14px;
    border-top: 1px solid #3d536f;
    font-size: 1rem;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    font-weight: 700;
    color: #3f556e !important;
}

.onoc-product-description p {
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.36;
}

.onoc-product-price {
    margin-top: auto !important;
    margin-bottom: 4px !important;
    font-family: 'Sora', 'Manrope', 'Segoe UI', sans-serif;
    font-size: clamp(2.8rem, 4vw, 3.8rem) !important;
    color: #1a304a !important;
}

.onoc-product-price span {
    font-size: 1.1rem !important;
    color: #4f647a !important;
}

.onoc-product-period {
    font-size: 1.1rem !important;
    font-weight: 600;
    color: #8a97a6 !important;
    margin-bottom: 20px !important;
}

.onoc-product-features {
    margin-bottom: 22px !important;
}

.onoc-product-features li {
    padding-left: 26px !important;
    font-size: 1.08rem !important;
    color: #30465f !important;
    margin-bottom: 10px !important;
}

.onoc-product-features li::before {
    content: "" !important;
    width: 10px;
    height: 10px;
    left: 1px;
    top: 8px;
    border-radius: 1px;
    transform: rotate(45deg);
    background: var(--ot-accent);
}

.onoc-product-select-btn {
    border-radius: 12px !important;
    border: 0 !important;
    padding: 16px 18px !important;
    background: var(--ot-accent) !important;
    color: #ffffff !important;
    font-size: 1.2rem !important;
    font-weight: 700 !important;
    box-shadow: 6px 6px 0 #2582cc;
}

.onoc-product-select-btn:hover,
.onoc-product-card:hover .onoc-product-select-btn,
.onoc-product-card.selected .onoc-product-select-btn {
    background: var(--ot-accent-strong) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
}

.onoc-product-card.popular .onoc-product-name,
.onoc-product-card.popular .onoc-product-description,
.onoc-product-card.popular .onoc-product-description li,
.onoc-product-card.popular .onoc-product-features li,
.onoc-product-card.popular .onoc-product-price,
.onoc-product-card.popular .onoc-product-period,
.onoc-product-card.popular .onoc-product-price span,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-name,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-description,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-description li,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-features li,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-price,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-period,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-price span {
    color: #f3f9ff !important;
}

.onoc-product-card.popular .onoc-product-description,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-description {
    border-top-color: rgba(186, 213, 235, 0.34);
}

.onoc-product-card.popular .onoc-product-features li::before,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-features li::before {
    background: #ff6a45;
}

.onoc-product-card.popular .onoc-product-description li::before,
.onoc-products-grid .onoc-product-card:nth-child(2):not(.popular) .onoc-product-description li::before {
    background: #f6fbff !important;
    color: #1f6299 !important;
}

.onoc-product-card.selected {
    box-shadow: 0 0 0 2px rgba(248, 79, 43, 0.3), 10px 10px 0 rgba(18, 122, 166, 0.66), 0 16px 34px rgba(11, 31, 53, 0.08) !important;
}

/* Footer im Brand-Blue, etwas dunkler als Karten */
.ontopic-footer {
    background-image: linear-gradient(145deg, #206aa8 0%, #1b5f97 52%, #154d7d 100%) !important;
    background-color: #1b5f97 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.18) !important;
}

.ontopic-footer .footer-brand .logo-text a {
    color: #ffffff !important;
}

.ontopic-footer .footer-title {
    color: #d8ebff !important;
}

.ontopic-footer .footer-list a,
.ontopic-footer .footer-address,
.ontopic-footer .footer-brand p,
.ontopic-footer .copyright {
    color: rgba(238, 246, 255, 0.9) !important;
}

.ontopic-footer .footer-list a:hover {
    color: #ffffff !important;
}

@media (max-width: 980px) {
    .hero-fullwidth {
        min-height: clamp(390px, 60vh, 640px) !important;
    }

    .hero-content {
        padding: clamp(1.5rem, 6vw, 2.8rem) 16px !important;
    }
}

@media (max-width: 768px) {
    .hero-fullwidth {
        min-height: clamp(360px, 58vh, 520px) !important;
    }

    .hero-fullwidth h1 {
        font-size: clamp(2.05rem, 10vw, 3.2rem) !important;
    }

    .hero-fullwidth .hero-subtitle {
        font-size: clamp(1rem, 5.1vw, 1.25rem) !important;
    }

    .hero-fullwidth::after {
        width: 55%;
        height: 22%;
    }

    body.page-id-12 .page-hero,
    body.page-id-30 .page-hero {
        min-height: clamp(320px, 50vh, 470px) !important;
        padding: clamp(1.6rem, 6vw, 2.3rem) 0 !important;
    }

    body.page-id-12 .page-hero::after,
    body.page-id-30 .page-hero::after {
        width: 46%;
        height: 18%;
    }

    body.page-id-12 .page-hero h1,
    body.page-id-30 .page-hero h1 {
        font-size: clamp(2.3rem, 11vw, 3.7rem) !important;
    }

    body.page-id-12 .page-hero .hero-subtitle,
    body.page-id-30 .page-hero .hero-subtitle {
        font-size: 1.08rem !important;
    }

    .section-cta,
    .cta-section .container {
        padding: 1rem !important;
    }

    .ot-cta-actions {
        gap: 10px;
    }

    .ot-cta-actions .ot-cta-btn {
        width: 100%;
        min-width: 0;
    }

    .onoc-product-card {
        padding: 24px 20px 20px !important;
        box-shadow: 8px 8px 0 rgba(18, 122, 166, 0.58), 0 14px 30px rgba(11, 31, 53, 0.12) !important;
    }

    .onoc-product-card.popular {
        box-shadow: 8px 8px 0 rgba(15, 87, 146, 0.86), 0 14px 30px rgba(7, 20, 33, 0.25) !important;
    }

    .onoc-product-name {
        font-size: clamp(1.8rem, 8vw, 2.35rem) !important;
    }

    .onoc-product-description {
        font-size: 0.95rem;
    }

    .onoc-product-description p {
        font-size: 0.95rem;
    }

    .onoc-product-price {
        font-size: clamp(2.5rem, 12vw, 3.3rem) !important;
    }

    .onoc-product-price span,
    .onoc-product-period {
        font-size: 1.02rem !important;
    }

    .onoc-product-features li {
        font-size: 1.12rem !important;
    }

    .onoc-product-select-btn {
        font-size: 1.1rem !important;
        padding: 14px 16px !important;
    }
}
