/* GraphicBidu SEO Growth — service landing pages and resource hub */
.seo-landing-shell { width: min(100% - 2rem, 1180px); margin-inline: auto; }
.seo-landing-hero, .seo-resources-hero { padding: clamp(2.1rem, 5vw, 4.4rem) 0 clamp(2.5rem, 5vw, 4.5rem); background: var(--surface, #fff); }
.seo-landing-hero__grid { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(280px, .75fr); gap: clamp(1.25rem, 4vw, 4rem); align-items: end; }
.seo-landing-hero h1, .seo-resources-hero h1 { max-width: 20ch; margin: .35rem 0 1rem; font-size: clamp(2.3rem, 5vw, 5.4rem); line-height: .98; letter-spacing: -.055em; text-wrap: balance; }
.seo-resources-hero > .seo-landing-shell > p:not(.eyebrow) { max-width: 68ch; font-size: clamp(1.05rem, 2vw, 1.3rem); line-height: 1.7; color: var(--text-muted, #475569); }
.seo-landing-hero__summary { max-width: 65ch; color: var(--text-muted, #475569); font-size: clamp(1.04rem, 2vw, 1.28rem); line-height: 1.72; }
.seo-breadcrumbs { display: flex; flex-wrap: wrap; align-items: center; row-gap: .32rem; column-gap: .45rem; margin: 0 0 .9rem; max-width: min(100%, 62rem); color: var(--text-muted, #64748b); font-size: .88rem; line-height: 1.35; }
.seo-breadcrumbs__link { color: inherit; text-decoration: none; text-underline-offset: .2em; }
.seo-breadcrumbs__link:hover,
.seo-breadcrumbs__link:focus-visible { color: var(--text, #0f172a); text-decoration: underline; }
.seo-breadcrumbs__separator { color: rgba(100, 116, 139, .72); flex: 0 0 auto; }
.seo-breadcrumbs__current { color: var(--text, #0f172a); font-weight: 600; max-width: 100%; overflow-wrap: anywhere; }
.seo-landing-hero__actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.65rem; }
.seo-landing-hero__panel { display: grid; gap: 1rem; padding: clamp(1.25rem, 3vw, 2rem); border: 1px solid rgba(15,23,42,.12); border-radius: 1.25rem; background: #111827; color: #fff; box-shadow: 0 20px 50px rgba(15,23,42,.14); }
.seo-landing-hero__panel .eyebrow, .seo-landing-hero__panel h2 { color: inherit; }
.seo-landing-hero__panel h2 { margin: 0; font-size: clamp(1.25rem, 2vw, 1.65rem); line-height: 1.15; }
.seo-landing-hero__panel ul { margin: 0; padding-left: 1.1rem; display: grid; gap: .7rem; color: rgba(255,255,255,.78); line-height: 1.5; }
.seo-section { padding-block: clamp(3.2rem, 7vw, 6.5rem); }
.seo-section--tint { background: #f5f5f4; }
.seo-section-heading { max-width: 680px; margin-bottom: clamp(1.3rem, 3vw, 2.5rem); }
.seo-section-heading h2 { max-width: 20ch; margin: .3rem 0 .85rem; font-size: clamp(1.9rem, 4vw, 3.4rem); line-height: 1.04; letter-spacing: -.045em; }
.seo-section-heading p:not(.eyebrow) { color: var(--text-muted, #475569); line-height: 1.7; }
.seo-outcome-grid, .seo-resource-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.seo-info-card, .seo-resource-card { min-width: 0; padding: 1.25rem; border: 1px solid rgba(15,23,42,.12); border-radius: 1rem; background: #fff; box-shadow: 0 8px 24px rgba(15,23,42,.045); }
.seo-info-card p, .seo-resource-card p { margin: 0; color: var(--text-muted, #475569); line-height: 1.65; overflow-wrap: anywhere; }
.seo-info-card--dark { background: #111827; border-color: #111827; }
.seo-info-card--dark p { color: rgba(255,255,255,.86); }
.seo-process-list { display: grid; gap: 1px; padding: 0; margin: 0; list-style: none; border-top: 1px solid rgba(15,23,42,.12); }
.seo-process-list li { display: grid; grid-template-columns: minmax(72px,.22fr) minmax(0,1fr); gap: 1rem; padding: 1.2rem 0; border-bottom: 1px solid rgba(15,23,42,.12); }
.seo-process-list__number { color: var(--text-muted, #64748b); font-variant-numeric: tabular-nums; }
.seo-process-list h3 { margin: 0 0 .4rem; font-size: clamp(1.1rem, 2vw, 1.35rem); }
.seo-process-list p { margin: 0; color: var(--text-muted, #475569); line-height: 1.65; }
.seo-landing-faq-grid { display: grid; grid-template-columns: minmax(0,.8fr) minmax(0,1.2fr); gap: clamp(1.5rem, 5vw, 5rem); }
.seo-faq-list { border-top: 1px solid rgba(15,23,42,.12); }
.seo-faq-list details { border-bottom: 1px solid rgba(15,23,42,.12); padding: 1rem 0; }
.seo-faq-list summary { cursor: pointer; font-weight: 750; list-style: none; padding-right: 2rem; position: relative; }
.seo-faq-list summary::-webkit-details-marker { display: none; }
.seo-faq-list summary::after { content: '+'; position: absolute; right: .15rem; top: -.2rem; font-size: 1.45rem; font-weight: 400; }
.seo-faq-list details[open] summary::after { content: '−'; }
.seo-faq-list p { margin: .85rem 2rem .1rem 0; color: var(--text-muted, #475569); line-height: 1.7; }
.seo-final-cta { background: #111827; color: #fff; padding-block: clamp(3rem, 6vw, 5rem); }
.seo-final-cta__inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.seo-final-cta h2 { max-width: 22ch; margin: .35rem 0 0; color: #fff; font-size: clamp(1.8rem, 4vw, 3rem); line-height: 1.05; letter-spacing: -.04em; }
.seo-final-cta .eyebrow { color: rgba(255,255,255,.68); }
.seo-final-cta .button-primary { background: #fff; color: #111827; border-color: #fff; }
.seo-final-cta .button-ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.seo-resource-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.seo-resource-card { display: grid; gap: .85rem; align-content: start; min-height: 100%; }
.seo-resource-card h2 { margin: 0; font-size: 1.3rem; line-height: 1.2; overflow-wrap: anywhere; }
.seo-resource-card .text-link { margin-top: auto; color: inherit; font-weight: 750; text-decoration-thickness: 1px; text-underline-offset: .22em; }
[data-theme="dark"] .seo-landing-hero, [data-theme="dark"] .seo-resources-hero { background: #0b1120; }
[data-theme="dark"] .seo-section--tint { background: #101827; }
[data-theme="dark"] .seo-breadcrumbs { color: rgba(203,213,225,.84); }
[data-theme="dark"] .seo-breadcrumbs__link:hover,
[data-theme="dark"] .seo-breadcrumbs__link:focus-visible,
[data-theme="dark"] .seo-breadcrumbs__current { color: #f8fafc; }
[data-theme="dark"] .seo-breadcrumbs__separator { color: rgba(148,163,184,.78); }
[data-theme="dark"] .seo-info-card, [data-theme="dark"] .seo-resource-card { background: #111827; border-color: rgba(148,163,184,.2); }
[data-theme="dark"] .seo-info-card p, [data-theme="dark"] .seo-resource-card p, [data-theme="dark"] .seo-section-heading p:not(.eyebrow), [data-theme="dark"] .seo-landing-hero__summary, [data-theme="dark"] .seo-process-list p, [data-theme="dark"] .seo-faq-list p { color: rgba(226,232,240,.78); }
[data-theme="dark"] .seo-process-list, [data-theme="dark"] .seo-process-list li, [data-theme="dark"] .seo-faq-list, [data-theme="dark"] .seo-faq-list details { border-color: rgba(148,163,184,.2); }
@media (max-width: 900px) { .seo-landing-hero__grid, .seo-landing-faq-grid { grid-template-columns: minmax(0,1fr); } .seo-outcome-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .seo-resource-grid { grid-template-columns: repeat(2,minmax(0,1fr)); } .seo-final-cta__inner { align-items: flex-start; flex-direction: column; } }
@media (max-width: 620px) { .seo-landing-shell { width: min(100% - 1.25rem, 1180px); } .seo-landing-hero h1, .seo-resources-hero h1 { font-size: clamp(2.25rem, 13vw, 3.55rem); } .seo-breadcrumbs { row-gap: .2rem; column-gap: .38rem; margin-bottom: .75rem; font-size: .8rem; } .seo-breadcrumbs__separator--tail { display: none; } .seo-breadcrumbs__current { flex-basis: 100%; } .seo-outcome-grid, .seo-resource-grid { grid-template-columns: minmax(0,1fr); } .seo-process-list li { grid-template-columns: 48px minmax(0,1fr); } .seo-landing-hero__actions .button, .seo-final-cta .button { width: 100%; justify-content: center; } }
