
/* assets/css/design-system.min.css */
.so-skip-link{position:fixed;top:0;left:0;transform:translateY(-120%);z-index:100000;padding:12px 20px;background:var(--n-900);color:#fff;font-weight:700;text-decoration:none;border-radius:0 0 8px 0;transition:transform 0.2s}.so-skip-link:focus{transform:translateY(0);outline:2px solid var(--c-cyan);outline-offset:2px}:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px;border-radius:var(--radius-sm)}main:focus,main:focus-visible{outline:none}.so-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.so-hero-visual{position:relative;aspect-ratio:4/5;background:var(--n-50);border:1px solid var(--n-200);border-radius:var(--radius-lg);padding:24px;overflow:hidden}.so-hero-visual::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--n-200) 1px,transparent 1px),linear-gradient(90deg,var(--n-200) 1px,transparent 1px);background-size:24px 24px;opacity:0.5}.so-visual-card{position:relative;background:white;border:1px solid var(--n-200);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:8px;display:flex;align-items:center;gap:10px;font-size:0.8125rem}.so-visual-card.top{border-color:var(--c-magenta);box-shadow:0 4px 16px rgba(214,40,40,0.15);transform:translateX(-12px)}.so-visual-rank{font-family:var(--font-mono);font-weight:700;color:var(--n-500);min-width:24px}.so-visual-rank.top-rank{color:var(--c-magenta)}.so-visual-bar{flex:1;height:8px;background:var(--n-100);border-radius:100px;overflow:hidden}.so-visual-bar-fill{height:100%;background:linear-gradient(90deg,var(--c-cyan),var(--c-magenta));border-radius:100px}.so-section{padding:80px 0;border-top:1px solid var(--n-200)}.so-section-inner{max-width:var(--container);margin:0 auto;padding:0 32px}.so-section-eyebrow{font-family:var(--font-mono);font-size:0.8125rem;font-weight:600;color:var(--c-cyan);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:12px;display:block;padding:8px 16px}.so-section h2{font-size:clamp(1.75rem,3.5vw,2.5rem);font-weight:800;line-height:1.1;letter-spacing:-0.025em;margin:0 0 16px;max-width:720px}.so-section-lede{font-size:1.125rem;color:var(--n-700);max-width:640px;margin:0 0 48px}.so-trust-bar{background:var(--n-50);padding:40px 0;position:relative}.so-trust-bar::before,.so-trust-bar::after{content:'';position:absolute;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--n-200) 20%,var(--n-200) 80%,transparent 100%)}.so-trust-bar::before{top:0}.so-trust-bar::after{bottom:0}.so-trust-inner{max-width:var(--container);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:40px}.so-trust-label{font-family:var(--font-mono);font-size:0.75rem;color:var(--n-700);text-transform:uppercase;letter-spacing:0.1em;font-weight:600;max-width:140px;line-height:1.4;border-left:3px solid var(--c-magenta);padding-left:14px}.so-trust-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.so-trust-stats>div{background:var(--n-0);border:1px solid var(--n-200);border-radius:var(--radius-md);padding:18px 22px;position:relative;clip-path:polygon(0 0,calc(100% - 14px) 0,100% 14px,100% 100%,0 100%);transition:border-color 0.2s,transform 0.2s}.so-trust-stats>div:hover{border-color:var(--c-cyan);transform:translateY(-2px)}.so-trust-stats>div::after{content:'';position:absolute;top:0;right:0;width:14px;height:14px;background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-trust-stat-num{font-size:1.5rem;font-weight:800;letter-spacing:-0.02em;line-height:1.1;color:var(--n-900);margin-bottom:4px}.so-trust-stat-label{font-size:0.8125rem;color:var(--n-700);line-height:1.4}@media (max-width:768px){.so-trust-inner{grid-template-columns:1fr;gap:20px}.so-trust-stats{grid-template-columns:1fr;gap:10px}}.so-service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.so-service-card{background:var(--n-0);border:1px solid var(--n-200);border-radius:var(--radius-lg);padding:28px;transition:all 0.2s;text-decoration:none;color:inherit;position:relative;overflow:hidden;display:block}.so-service-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:var(--c-cyan);transition:height 0.3s}.so-service-card:hover{border-color:var(--n-300);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.06)}.so-service-card:hover::before{height:100%}.so-service-card .icon{width:44px;height:44px;background:var(--c-cyan-soft);color:var(--c-cyan);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:1.375rem;font-weight:700;font-family:var(--font-mono)}.so-service-card h3{font-size:1.25rem;font-weight:700;margin:0 0 8px;letter-spacing:-0.02em}.so-service-card p{color:var(--n-700);font-size:0.9375rem;margin:0 0 16px}.so-service-card .link{color:var(--c-magenta);font-weight:600;font-size:0.875rem;display:inline-flex;align-items:center;gap:4px}.so-with-sidebar{display:grid;grid-template-columns:1fr 280px;gap:60px}.so-sidebar{position:sticky;top:100px;align-self:start;display:flex;flex-direction:column;gap:16px}.so-sidebar-block{background:var(--n-0);border:1px solid var(--n-200);padding:24px;position:relative;clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,0 100%);transition:transform 0.2s,box-shadow 0.2s}.so-sidebar-block:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.06)}.so-sidebar-block::after{content:'';position:absolute;top:0;right:0;width:18px;height:18px;background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-sidebar-block:nth-child(2)::after{background:linear-gradient(135deg,transparent 50%,var(--c-magenta) 50%)}.so-sidebar-block:nth-child(3)::after{background:linear-gradient(135deg,transparent 50%,var(--c-yellow) 50%)}.so-sidebar-block:nth-child(4)::after{background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-sidebar-block h3{font-size:0.75rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.1em;color:var(--n-900);margin:0 0 16px;font-weight:700;padding-bottom:10px;position:relative}.so-sidebar-block h3::after{content:'';position:absolute;bottom:0;left:0;width:28px;height:2px;background:var(--c-cyan)}.so-sidebar-block:nth-child(2) h3::after{background:var(--c-magenta)}.so-sidebar-block:nth-child(3) h3::after{background:var(--c-yellow)}.so-sidebar-block:nth-child(4) h3::after{background:var(--c-cyan)}.so-sidebar-block ul{list-style:none;margin:0;padding:0}.so-sidebar-block li{border-top:1px solid var(--n-100)}.so-sidebar-block li:first-child{border-top:none}.so-sidebar-block li a{color:var(--n-900);text-decoration:none;font-size:0.9375rem;font-weight:600;display:block;padding:11px 10px;margin:0 -10px;border-radius:var(--radius-sm);transition:background 0.15s,color 0.15s,padding 0.15s;position:relative}.so-sidebar-block li a::before{content:'→';position:absolute;right:10px;top:50%;transform:translateY(-50%);opacity:0;color:var(--c-magenta);font-weight:700;transition:opacity 0.15s,transform 0.2s}.so-sidebar-block li a:hover,.so-sidebar-block li a:focus-visible{background:var(--c-yellow-soft);color:var(--n-900);padding-left:14px;padding-right:28px}.so-sidebar-block li a:hover::before,.so-sidebar-block li a:focus-visible::before{opacity:1;transform:translateY(-50%) translateX(0)}.so-sidebar-block li a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px}.so-sidebar-block li a small{display:block;color:var(--n-700);font-weight:400;font-size:0.8125rem;margin-top:2px;line-height:1.4}.so-sidebar-trust{background:linear-gradient(135deg,var(--c-magenta) 0%,#b91c1c 100%);color:var(--n-0);border:none;position:relative;overflow:hidden}.so-sidebar-trust::before{content:'';position:absolute;top:-40%;right:-30%;width:200px;height:200px;background:radial-gradient(circle,var(--c-yellow) 0%,transparent 65%);opacity:0.4;pointer-events:none}.so-sidebar-trust::after{background:linear-gradient(135deg,transparent 50%,var(--c-yellow) 50%)}.so-sidebar-trust h3{color:var(--n-0);position:relative;z-index:1}.so-sidebar-trust h3::after{background:var(--c-yellow)}.so-sidebar-trust p{color:rgba(255,255,255,0.92);font-size:0.9375rem;line-height:1.5;margin:0 0 18px;position:relative;z-index:1;font-weight:500}.so-sidebar-trust .so-sidebar-cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:14px 16px;background:var(--n-0);color:var(--n-900);font-weight:700;font-size:0.9375rem;text-decoration:none;border-radius:var(--radius-md);position:relative;z-index:1;transition:background 0.15s,transform 0.15s,color 0.15s}.so-sidebar-trust .so-sidebar-cta:hover,.so-sidebar-trust .so-sidebar-cta:focus-visible{background:var(--c-yellow);color:var(--n-900);transform:translateY(-2px)}.so-sidebar-trust .so-sidebar-cta:focus-visible{outline:2px solid var(--n-0);outline-offset:2px}.so-prose h2{font-size:clamp(1.625rem,3vw,2.25rem);font-weight:800;letter-spacing:-0.025em;margin:60px 0 16px;line-height:1.15}.so-prose h2:first-child{margin-top:0}.so-prose h3{font-size:1.375rem;font-weight:700;letter-spacing:-0.02em;margin:40px 0 12px}.so-prose p{margin:0 0 16px;color:var(--n-700)}.so-prose p strong{color:var(--n-900);font-weight:700}.so-prose ul,.so-prose ol{margin:16px 0 24px 24px;color:var(--n-700)}.so-prose li{margin-bottom:8px}.so-prose a,.entry-content p a,.entry-content li a,.so-section p a,.so-section li a{color:#d62828;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:rgba(185,28,28,0.4);transition:color 0.15s,text-decoration-color 0.15s;font-weight:600}.so-prose a:hover,.so-prose a:focus-visible,.entry-content p a:hover,.entry-content p a:focus-visible,.entry-content li a:hover,.entry-content li a:focus-visible,.so-section p a:hover,.so-section p a:focus-visible,.so-section li a:hover,.so-section li a:focus-visible{color:#b91c1c;text-decoration-color:#b91c1c;text-decoration-thickness:2px}.so-prose a:focus-visible,.entry-content p a:focus-visible,.entry-content li a:focus-visible,.so-section p a:focus-visible,.so-section li a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px;border-radius:2px}.entry-content a.so-btn,.entry-content a.so-btn-primary,.entry-content a.so-btn-secondary,.so-sidebar-block a,.so-mega-col a,.so-breadcrumbs a,.so-cta-band a,.so-cta-inner a{color:inherit;text-decoration:inherit;font-weight:inherit}.so-stat-box{background:var(--c-cyan-soft);padding:24px 28px;margin:36px 0;position:relative;clip-path:polygon(0 0,calc(100% - 20px) 0,100% 20px,100% 100%,0 100%);border-left:4px solid var(--c-cyan)}.so-stat-box::after{content:'';position:absolute;top:0;right:0;width:20px;height:20px;background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-stat-box .num{font-size:2.25rem;font-weight:800;letter-spacing:-0.025em;color:var(--n-900);line-height:1;margin-bottom:6px}.so-stat-box .label{font-size:0.9375rem;color:var(--n-700);line-height:1.5;max-width:600px}.so-geo-slot{background:var(--c-yellow-soft);border:2px dashed var(--c-yellow);border-radius:var(--radius-lg);padding:32px;margin:40px 0;text-align:center}.so-geo-slot.is-empty{}.so-geo-slot .tag{display:inline-block;background:var(--c-key);color:white;font-family:var(--font-mono);font-size:0.6875rem;padding:4px 10px;border-radius:4px;margin-bottom:12px;letter-spacing:0.05em}.so-geo-slot h4{font-size:1.25rem;margin:0 0 8px}.so-geo-slot p{color:var(--n-700);font-size:0.9375rem;margin:0}.so-faq-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:60px}.so-faq{border-bottom:1px solid var(--n-200);padding:20px 0}.so-faq summary{font-weight:600;font-size:1.0625rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--n-900)}.so-faq summary::-webkit-details-marker{display:none}.so-faq summary::after{content:'+';font-size:1.375rem;font-weight:400;color:var(--n-500);transition:transform 0.2s;line-height:1}.so-faq[open] summary::after{transform:rotate(45deg);color:var(--c-magenta)}.so-faq p{margin:12px 0 0;color:var(--n-700);font-size:1rem}.so-cta-band{background:linear-gradient(135deg,var(--c-magenta) 0%,#d62828 50%,var(--c-magenta) 100%);color:var(--n-0);position:relative;overflow:hidden;margin-top:80px}.so-cta-band::before{content:'';position:absolute;top:-40%;right:-10%;width:600px;height:600px;background:radial-gradient(circle,var(--c-yellow) 0%,transparent 60%);opacity:0.22;pointer-events:none}.so-cta-band::after{content:'';position:absolute;bottom:-50%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,var(--c-cyan) 0%,transparent 60%);opacity:0.25;pointer-events:none}.so-cta-inner{max-width:var(--container);margin:0 auto;padding:72px 32px;position:relative;display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:center;z-index:1}.so-cta-inner h2{color:var(--n-0);margin:0 0 16px;font-size:clamp(1.875rem,3.5vw,2.625rem);font-weight:800;letter-spacing:-0.025em;line-height:1.1}.so-cta-inner p{color:rgba(255,255,255,0.95);font-size:1.125rem;line-height:1.55;margin:0;max-width:480px;font-weight:500}.so-cta-inner .so-btn-primary{background:var(--n-0);color:var(--n-900);font-size:1.0625rem;padding:18px 32px;box-shadow:0 8px 28px rgba(0,0,0,0.25);font-weight:700}.so-cta-inner .so-btn-primary:hover,.so-cta-inner .so-btn-primary:focus-visible{background:var(--c-yellow);color:var(--n-900);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,0.3)}.so-cta-inner .so-btn-primary:focus-visible{outline:2px solid var(--n-0);outline-offset:3px}@media (max-width:768px){.so-cta-inner{grid-template-columns:1fr;gap:24px;padding:48px 24px}}.so-footer{background:var(--n-50);padding:60px 0 40px;border-top:1px solid var(--n-200)}.so-footer-inner{max-width:var(--container);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}.so-footer-col .so-footer-heading{font-size:0.8125rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.08em;color:var(--n-900);margin:0 0 16px;font-weight:700}.so-footer-col ul{list-style:none;margin:0;padding:0}.so-footer-col li{margin-bottom:8px}.so-footer-col a{color:var(--n-700);text-decoration:none;font-size:0.9375rem;font-weight:500}.so-footer-col a:hover,.so-footer-col a:focus-visible{color:#d62828;text-decoration:underline}.so-footer-col a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px;border-radius:2px}@media (max-width:900px){.so-section{padding:60px 0}.so-with-sidebar,.so-faq-grid,.so-cta-inner,.so-footer-inner{grid-template-columns:1fr;gap:32px}.so-sidebar{position:static}}.so-breadcrumbs span:not(.current):not(.sep){color:var(--n-500)}@media print{.so-header,.so-cta-band,.so-footer,.so-sidebar{display:none}body{font-size:12pt;color:black}}.so-cta-band-content{max-width:var(--container);margin:0 auto;padding:72px 32px;position:relative;display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:center;z-index:1}.so-cta-band-content h2{color:var(--n-0);margin:0 0 16px;font-size:clamp(1.875rem,3.5vw,2.625rem);font-weight:800;letter-spacing:-0.025em;line-height:1.1}.so-cta-band-content p{color:rgba(255,255,255,0.95);font-size:1.125rem;line-height:1.55;margin:0 0 24px;max-width:600px;font-weight:500}@media (max-width:768px){.so-cta-band-content{grid-template-columns:1fr;gap:24px;padding:48px 24px}}.so-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:16px 28px;min-height:48px;border-radius:var(--radius-md);font-family:inherit;font-weight:700;font-size:1rem;line-height:1.2;text-decoration:none;border:none;cursor:pointer;transition:transform 0.12s,box-shadow 0.2s,background 0.15s,color 0.15s}.so-cta:focus-visible{outline:2px solid var(--n-0);outline-offset:3px}.so-cta-primary-inverse{background:var(--n-0);color:var(--n-900);box-shadow:0 4px 16px rgba(0,0,0,0.25)}.so-cta-primary-inverse:hover,.so-cta-primary-inverse:focus-visible{background:var(--c-yellow);color:var(--n-900);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.3)}.so-cta-primary{background:#d62828;color:var(--n-0);box-shadow:0 2px 0 rgba(0,0,0,0.1),0 8px 24px rgba(185,28,28,0.35)}.so-cta-primary:hover,.so-cta-primary:focus-visible{background:#b91c1c;transform:translateY(-2px);box-shadow:0 12px 32px rgba(185,28,28,0.5)}.so-cta-secondary{background:var(--n-0);color:var(--n-900);border:2px solid var(--n-900)}.so-cta-secondary:hover,.so-cta-secondary:focus-visible{background:var(--n-900);color:var(--n-0)}.so-page-sidebar,aside.so-aside-sidebar{position:sticky;top:100px;align-self:start;display:flex;flex-direction:column;gap:16px}.so-sidebar-card,.so-sidebar-section,.so-sidebar-nav,.so-related-topics,.so-quick-nav,.so-toc{background:var(--n-0);border:1px solid var(--n-200);padding:24px;position:relative;clip-path:polygon(0 0,calc(100% - 18px) 0,100% 18px,100% 100%,0 100%);transition:transform 0.2s,box-shadow 0.2s}.so-sidebar-card:hover,.so-sidebar-section:hover,.so-sidebar-nav:hover,.so-related-topics:hover,.so-quick-nav:hover,.so-toc:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.06)}.so-sidebar-card::after,.so-sidebar-section::after,.so-sidebar-nav::after,.so-related-topics::after,.so-quick-nav::after,.so-toc::after{content:'';position:absolute;top:0;right:0;width:18px;height:18px;background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-sidebar-card h2,.so-sidebar-card h3,.so-sidebar-card h4,.so-sidebar-section h2,.so-sidebar-section h3,.so-sidebar-section h4,.so-sidebar-nav h2,.so-sidebar-nav h3,.so-sidebar-nav h4,.so-related-topics h2,.so-related-topics h3,.so-related-topics h4,.so-quick-nav h2,.so-quick-nav h3,.so-quick-nav h4,.so-toc h2,.so-toc h3,.so-toc h4{font-size:0.75rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.1em;color:var(--n-900);margin:0 0 16px;font-weight:700;padding-bottom:10px;position:relative}.so-sidebar-card h2::after,.so-sidebar-card h3::after,.so-sidebar-card h4::after,.so-sidebar-section h2::after,.so-sidebar-section h3::after,.so-sidebar-section h4::after,.so-sidebar-nav h2::after,.so-sidebar-nav h3::after,.so-sidebar-nav h4::after,.so-related-topics h2::after,.so-related-topics h3::after,.so-related-topics h4::after,.so-quick-nav h2::after,.so-quick-nav h3::after,.so-quick-nav h4::after,.so-toc h2::after,.so-toc h3::after,.so-toc h4::after{content:'';position:absolute;bottom:0;left:0;width:28px;height:2px;background:var(--c-cyan)}.so-sidebar-card ul,.so-sidebar-section ul,.so-sidebar-nav ul,.so-related-topics ul,.so-quick-nav ul,.so-toc ul{list-style:none;margin:0;padding:0}.so-sidebar-card li,.so-sidebar-section li,.so-sidebar-nav li,.so-related-topics li,.so-quick-nav li,.so-toc li{border-top:1px solid var(--n-100)}.so-sidebar-card li:first-child,.so-sidebar-section li:first-child,.so-sidebar-nav li:first-child,.so-related-topics li:first-child,.so-quick-nav li:first-child,.so-toc li:first-child{border-top:none}.so-sidebar-card li a,.so-sidebar-section li a,.so-sidebar-nav li a,.so-related-topics li a,.so-quick-nav li a,.so-toc li a{color:var(--n-900);text-decoration:none;font-size:0.9375rem;font-weight:600;display:block;padding:11px 10px;margin:0 -10px;border-radius:var(--radius-sm);transition:background 0.15s,color 0.15s,padding 0.15s;position:relative}.so-sidebar-card li a:hover,.so-sidebar-card li a:focus-visible,.so-sidebar-section li a:hover,.so-sidebar-section li a:focus-visible,.so-sidebar-nav li a:hover,.so-sidebar-nav li a:focus-visible,.so-related-topics li a:hover,.so-related-topics li a:focus-visible,.so-quick-nav li a:hover,.so-quick-nav li a:focus-visible,.so-toc li a:hover,.so-toc li a:focus-visible{background:var(--c-yellow-soft);color:var(--n-900);padding-left:14px}.so-sidebar-card li a:focus-visible,.so-sidebar-section li a:focus-visible,.so-sidebar-nav li a:focus-visible,.so-related-topics li a:focus-visible,.so-quick-nav li a:focus-visible,.so-toc li a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px}.so-hero .so-lede,.so-hero p.so-lede{font-size:1.25rem;color:var(--n-700);margin:0 0 36px;max-width:720px;line-height:1.55}.so-hero .so-trust-items{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}.so-hero .so-trust-item{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:var(--n-0);border:1px solid var(--n-200);border-radius:100px;font-size:0.9375rem;font-weight:600;color:var(--n-900);box-shadow:0 1px 3px rgba(0,0,0,0.04);transition:border-color 0.15s,transform 0.15s}.so-hero .so-trust-item:hover{border-color:var(--c-cyan);transform:translateY(-1px)}.so-hero .so-trust-icon{font-size:1.125rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}.so-hero .so-trust-text{font-weight:600}.so-trust-bar{background:var(--n-50);padding:40px 32px;position:relative;max-width:var(--container);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.so-trust-bar>.so-trust-bar-item{background:var(--n-0);border:1px solid var(--n-200);border-radius:var(--radius-md);padding:24px 28px;position:relative;clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,0 100%);transition:border-color 0.2s,transform 0.2s}.so-trust-bar>.so-trust-bar-item:hover{border-color:var(--c-cyan);transform:translateY(-2px)}.so-trust-bar>.so-trust-bar-item::after{content:'';position:absolute;top:0;right:0;width:16px;height:16px}.so-trust-bar>.so-trust-bar-item:nth-child(1)::after{background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-trust-bar>.so-trust-bar-item:nth-child(2)::after{background:linear-gradient(135deg,transparent 50%,var(--c-magenta) 50%)}.so-trust-bar>.so-trust-bar-item:nth-child(3)::after{background:linear-gradient(135deg,transparent 50%,var(--c-yellow) 50%)}.so-trust-bar-number{font-size:2rem;font-weight:800;letter-spacing:-0.025em;line-height:1.05;color:var(--n-900);margin-bottom:6px;font-family:var(--font-display);background:linear-gradient(120deg,var(--c-cyan),var(--c-magenta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.so-trust-bar-label{font-size:0.9375rem;color:var(--n-700);line-height:1.4;font-weight:500}@media (max-width:768px){.so-trust-bar{grid-template-columns:1fr;gap:12px;padding:32px 24px}}.so-hero{max-width:var(--container);margin:0 auto;padding:60px 32px 40px}.so-hero h1{font-size:clamp(2.25rem,5vw,3.5rem);font-weight:800;line-height:1.05;letter-spacing:-0.03em;margin:0 0 20px;max-width:900px}.so-hero .so-hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin:32px 0}.so-related-clusters{padding:64px 0;background:var(--n-50);position:relative;margin-top:40px}.so-related-inner{max-width:var(--container);margin:0 auto;padding:0 32px}.so-related-header{margin-bottom:40px;max-width:720px}.so-related-header .so-section-eyebrow{display:inline-block;padding:6px 14px;background:var(--n-0);border:1px solid var(--n-200);border-radius:100px;font-family:var(--font-mono);font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--n-700);margin-bottom:16px}.so-related-header h2{font-size:clamp(1.75rem,3vw,2.25rem);font-weight:800;letter-spacing:-0.025em;margin:0 0 12px;line-height:1.15;color:var(--n-900)}.so-related-header p{font-size:1.0625rem;color:var(--n-700);margin:0;line-height:1.55}.so-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.so-related-card{background:var(--n-0);border:1px solid var(--n-200);padding:28px;display:flex;flex-direction:column;text-decoration:none;color:inherit;position:relative;clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,0 100%);transition:transform 0.2s,box-shadow 0.2s,border-color 0.2s;min-height:200px}.so-related-card::after{content:'';position:absolute;top:0;right:0;width:22px;height:22px}.so-related-card--cyan::after{background:linear-gradient(135deg,transparent 50%,var(--c-cyan) 50%)}.so-related-card--magenta::after{background:linear-gradient(135deg,transparent 50%,var(--c-magenta) 50%)}.so-related-card--yellow::after{background:linear-gradient(135deg,transparent 50%,var(--c-yellow) 50%)}.so-related-card:hover,.so-related-card:focus-visible{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.08);border-color:var(--n-300)}.so-related-card:focus-visible{outline:2px solid var(--c-cyan);outline-offset:4px}.so-related-card-eyebrow{font-family:var(--font-mono);font-size:0.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--n-700);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--n-100);display:inline-block;align-self:flex-start}.so-related-card--cyan .so-related-card-eyebrow{border-bottom-color:var(--c-cyan);color:#b91c1c}.so-related-card--magenta .so-related-card-eyebrow{border-bottom-color:var(--c-magenta);color:#d62828}.so-related-card--yellow .so-related-card-eyebrow{border-bottom-color:var(--c-yellow);color:#b91c1c}.so-related-card-title{font-size:1.25rem;font-weight:800;letter-spacing:-0.02em;margin:0 0 10px;line-height:1.2;color:var(--n-900)}.so-related-card-desc{font-size:0.9375rem;color:var(--n-700);line-height:1.5;margin:0 0 16px;flex-grow:1}.so-related-card-arrow{font-size:1.25rem;font-weight:700;color:var(--n-900);transition:transform 0.2s,color 0.15s;align-self:flex-start}.so-related-card:hover .so-related-card-arrow,.so-related-card:focus-visible .so-related-card-arrow{transform:translateX(4px)}.so-related-card--cyan:hover .so-related-card-arrow{color:var(--c-cyan)}.so-related-card--magenta:hover .so-related-card-arrow{color:var(--c-magenta)}.so-related-card--yellow:hover .so-related-card-arrow{color:#b91c1c}@media (max-width:900px){.so-related-grid{grid-template-columns:1fr 1fr}}@media (max-width:600px){.so-related-grid{grid-template-columns:1fr}}
/* Beitragsbild auf Einzelbeiträgen (selbst gerendert, da .entry-header ausgeblendet) */
.soc-post-featured{margin:0 0 32px;border-radius:14px;overflow:hidden;line-height:0}
.soc-post-featured img{width:100%;height:auto;display:block}
/* Sidebar-Button (.soa-*) zentrieren – schlägt die zu breite Artikel-Regel .soa-sidebar a */
.soa-sidebar-block .soa-btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;text-align:center}
.so-footer-social{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.so-footer-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--n-200);border-radius:9px;color:var(--n-700);background:var(--n-0);transition:color .15s,border-color .15s,background .15s}.so-footer-social a:hover,.so-footer-social a:focus-visible{color:#d62828;border-color:#d62828;background:var(--n-50)}.so-footer-social a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px}.so-footer-social svg{width:18px;height:18px;fill:currentColor;display:block}

/* assets/css/soa-article.css */
/*
 * SEO-Agentur Artikel-Designsystem (.soa-*)
 * Zentral im Theme – Artikel/Seiten brauchen kein eigenes <style> mehr.
 * Wird global geladen (siehe functions.php -> soc_enqueue_assets).
 * Gepflegt an EINER Stelle: diese Datei.
 */

:root{
  --so-dark:var(--text,#1E1E1E);
  --so-text:var(--text-light,#555555);
  --so-muted:var(--text-light,#555555);
  --so-blue:var(--primary,#D62828);
  --so-pink:var(--primary,#D62828);
  --so-yellow:var(--primary,#D62828);
  --so-bg:var(--surface,#F8F8F8);
  --so-border:var(--border,#E6E6E6);
  --so-radius:18px;
  --so-shadow:0 18px 50px rgba(0,0,0,.08);
}

.soa-page{
  font-family:inherit;
  color:var(--so-text);
  line-height:1.75;
}

.soa-page *{box-sizing:border-box}

.soa-wrap{
  width:min(1180px,92vw);
  margin:0 auto;
}

.soa-breadcrumbs{
  font-size:13px;
  letter-spacing:.04em;
  margin:60px auto 18px;
  color:var(--so-muted);
}

.soa-breadcrumbs a{
  color:var(--so-muted);
  text-decoration:underline;
}

.soa-breadcrumbs .sep{
  margin:0 10px;
}

.soa-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 13px;
  border:1px solid var(--so-border);
  border-radius:999px;
  background:#fff;
  color:var(--so-blue);
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.12em;
  box-shadow:0 8px 24px rgba(214,40,40,.08);
}

.soa-hero{
  position:relative;
  overflow:hidden;
  padding:20px 0 50px;
}

.soa-hero:after{
  content:"";
  position:absolute;
  right:8%;
  top:5%;
  width:360px;
  height:360px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(214,40,40,.16),rgba(214,40,40,.07),transparent 68%);
  filter:blur(6px);
  pointer-events:none;
}

.soa-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);
  gap:50px;
  align-items:center;
  position:relative;
  z-index:2;
}

.soa-hero h1{
  max-width:780px;
  margin:24px 0 18px;
  color:var(--so-dark);
  font-size:clamp(38px,5vw,68px);
  line-height:1.02;
  letter-spacing:-.055em;
}

.soa-hero-lede{
  max-width:760px;
  font-size:19px;
  color:#555555;
  margin:0 0 24px;
}

.soa-hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:28px 0 0;
}

.soa-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:48px;
  padding:14px 22px;
  border-radius:8px;
  font-weight:800;
  text-decoration:none!important;
  transition:.2s ease;
  border:0;
}

.soa-btn-primary{
  color:#fff!important;
  background:linear-gradient(135deg,var(--so-blue),var(--so-pink));
  box-shadow:0 12px 28px rgba(214,40,40,.22);
}

.soa-btn-secondary{
  color:var(--so-dark)!important;
  background:#fff;
  border:1px solid var(--so-border);
}

.soa-btn:hover{
  transform:translateY(-2px);
}

.soa-hero-card{
  position:relative;
  background:#fff;
  border:1px solid var(--so-border);
  border-radius:var(--so-radius);
  padding:30px;
  box-shadow:var(--so-shadow);
}

.soa-hero-card:before{
  content:"";
  position:absolute;
  top:0;
  right:28px;
  width:18px;
  height:18px;
  background:var(--so-yellow);
  clip-path:polygon(100% 0,0 0,100% 100%);
}

.soa-hero-card h3{
  margin:0 0 14px;
  color:var(--so-dark);
  font-size:22px;
}

.soa-checklist{
  list-style:none;
  padding:0;
  margin:0;
}

.soa-checklist li{
  position:relative;
  padding-left:30px;
  margin:12px 0;
}

.soa-checklist li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--so-pink);
  font-weight:900;
}

.soa-trust-bar{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--so-border);
  border:1px solid var(--so-border);
  margin:30px 0 70px;
}

.soa-trust-item{
  background:#fff;
  padding:28px 24px;
}

.soa-trust-number{
  display:block;
  font-size:34px;
  line-height:1;
  font-weight:900;
  color:var(--so-blue);
}

.soa-trust-number strong{
  color:var(--so-pink);
}

.soa-trust-label{
  display:block;
  margin-top:8px;
  color:var(--so-dark);
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.16em;
}

.soa-logo-wall{
  background:#fff;
  border:1px solid var(--so-border);
  border-radius:var(--so-radius);
  padding:34px;
  margin:0 0 70px;
  box-shadow:var(--so-shadow);
}

.soa-logo-wall h2{
  margin:0 0 22px;
  color:var(--so-dark);
  font-size:28px;
  letter-spacing:-.03em;
}

.soa-logos{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}

.soa-logo{
  min-height:78px;
  border:1px dashed #e6e6e6;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--so-dark);
  background:linear-gradient(180deg,#fff,#f8f8f8);
  font-weight:900;
  font-size:14px;
  text-align:center;
}

.soa-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 280px;
  gap:58px;
  align-items:start;
}

.soa-prose h2{
  color:var(--so-dark);
  font-size:clamp(28px,3vw,42px);
  line-height:1.12;
  letter-spacing:-.045em;
  margin:58px 0 18px;
}

.soa-prose h3{
  color:var(--so-dark);
  font-size:24px;
  line-height:1.22;
  letter-spacing:-.025em;
  margin:32px 0 10px;
}

.soa-prose p{
  margin:0 0 18px;
}

.soa-card{
  background:#fff;
  border:1px solid var(--so-border);
  border-radius:var(--so-radius);
  padding:30px;
  margin:34px 0;
  box-shadow:var(--so-shadow);
  position:relative;
}

.soa-card:after{
  content:"";
  position:absolute;
  right:0;
  top:0;
  width:28px;
  height:28px;
  background:var(--so-blue);
  clip-path:polygon(100% 0,0 0,100% 100%);
}

.soa-card.pink:after{background:var(--so-pink)}
.soa-card.yellow:after{background:var(--so-yellow)}

.soa-card h3{
  margin-top:0;
}

.soa-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
  margin:28px 0;
}

.soa-mini-card{
  background:var(--so-bg);
  border:1px solid var(--so-border);
  border-radius:16px;
  padding:22px;
}

.soa-mini-card h3{
  margin-top:0;
  font-size:20px;
}

.soa-table{
  width:100%;
  border-collapse:collapse;
  overflow:hidden;
  border-radius:16px;
  margin:26px 0;
  background:#fff;
  border:1px solid var(--so-border);
}

.soa-table th,
.soa-table td{
  padding:18px;
  border-bottom:1px solid var(--so-border);
  text-align:left;
  vertical-align:top;
}

.soa-table th{
  background:#f8f8f8;
  color:var(--so-dark);
}

.soa-table tr:last-child td{
  border-bottom:0;
}

.soa-process{
  counter-reset:step;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  margin:30px 0;
}

.soa-step{
  counter-increment:step;
  padding:24px;
  border:1px solid var(--so-border);
  border-radius:16px;
  background:#fff;
  position:relative;
}

.soa-step:before{
  content:counter(step);
  width:34px;
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:var(--so-dark);
  color:#fff;
  font-weight:900;
  margin-bottom:14px;
}

.soa-sidebar{
  position:sticky;
  top:100px;
}

.soa-sidebar-block{
  background:#fff;
  border:1px solid var(--so-border);
  padding:24px;
  margin-bottom:24px;
  position:relative;
  box-shadow:0 10px 26px rgba(0,0,0,.05);
}

.soa-sidebar-block:after{
  content:"";
  position:absolute;
  right:0;
  top:0;
  width:20px;
  height:20px;
  background:var(--so-blue);
  clip-path:polygon(100% 0,0 0,100% 100%);
}

.soa-sidebar-block.pink{
  background:linear-gradient(135deg,var(--so-pink),#d62828);
  color:#fff;
}

.soa-sidebar-block.pink:after{
  background:var(--so-yellow);
}

.soa-sidebar-block h3{
  margin:0 0 16px;
  color:var(--so-dark);
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.16em;
}

.soa-sidebar-block.pink h3,
.soa-sidebar-block.pink p{
  color:#fff;
}

.soa-sidebar ul{
  list-style:none;
  margin:0;
  padding:0;
}

.soa-sidebar li{
  border-bottom:1px solid var(--so-border);
}

.soa-sidebar li:last-child{
  border-bottom:0;
}

.soa-sidebar li a{
  display:block;
  padding:11px 0;
  color:var(--so-pink);
  font-weight:800;
}

.soa-sidebar-block.pink .soa-btn{
  width:100%;
  color:#fff!important;
  background:var(--so-blue);
  margin-top:12px;
}

.soa-related{
  background:var(--so-bg);
  padding:70px 0;
  margin-top:80px;
}

.soa-related-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.soa-service-card{
  min-height:190px;
  background:#fff;
  border:1px solid var(--so-border);
  padding:28px;
  border-radius:14px;
  position:relative;
  transition:.2s ease;
}

.soa-service-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--so-shadow);
}

.soa-service-card:after{
  content:"";
  position:absolute;
  right:0;
  top:0;
  width:22px;
  height:22px;
  background:var(--so-blue);
  clip-path:polygon(100% 0,0 0,100% 100%);
}

.soa-service-card:nth-child(2n):after{background:var(--so-pink)}
.soa-service-card:nth-child(3n):after{background:var(--so-yellow)}

.soa-service-card span{
  display:block;
  color:var(--so-blue);
  font-size:11px;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:.16em;
}

.soa-service-card h3{
  color:var(--so-dark);
  margin:8px 0;
  font-size:24px;
}

.soa-card-link{
  position:absolute;
  inset:0;
  z-index:1;
  border-radius:14px;
}

.soa-card-link:focus-visible{
  outline:2px solid var(--so-blue);
  outline-offset:3px;
}

.soa-faq{
  margin:40px 0;
}

.soa-faq details{
  background:#fff;
  border:1px solid var(--so-border);
  border-radius:14px;
  margin-bottom:12px;
  padding:20px 22px;
}

.soa-faq summary{
  cursor:pointer;
  color:var(--so-dark);
  font-weight:900;
  font-size:18px;
}

.soa-final-cta{
  margin:70px 0 20px;
  padding:48px;
  border-radius:24px;
  background:linear-gradient(135deg,var(--so-dark),#1e1e1e);
  color:#fff;
  position:relative;
  overflow:hidden;
}

.soa-final-cta:after{
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:260px;
  height:260px;
  background:radial-gradient(circle,rgba(214,40,40,.45),transparent 65%);
}

.soa-final-cta h2{
  color:#fff;
  margin-top:0;
}

.soa-final-cta p{
  color:rgba(255,255,255,.86);
  max-width:760px;
}

@media(max-width:980px){
  .soa-hero-grid,
  .soa-main-grid,
  .soa-split,
  .soa-process{
    grid-template-columns:1fr;
  }
  .soa-sidebar{
    position:static;
  }
  .soa-trust-bar,
  .soa-logos,
  .soa-related-grid{
    grid-template-columns:repeat(2,1fr);
  }
}

@media(max-width:620px){
  .soa-trust-bar,
  .soa-logos,
  .soa-related-grid{
    grid-template-columns:1fr;
  }
  .soa-hero h1{
    font-size:38px;
  }
  .soa-final-cta{
    padding:30px;
  }
}

/* assets/css/mega-menu.min.css */
.so-nav{display:flex;gap:0;list-style:none;margin:0;padding:0;align-items:stretch}.so-nav>li{position:static}.so-nav>li>a{display:flex;align-items:center;gap:6px;padding:22px 16px;color:var(--n-900);text-decoration:none;font-weight:600;font-size:0.9375rem;transition:color 0.15s,background 0.15s;position:relative;cursor:pointer}.so-nav>li>a:hover,.so-nav>li:hover>a,.so-nav>li.so-has-mega:focus-within>a{color:var(--c-magenta);background:rgba(0,0,0,0.02)}.so-nav>li>a:focus-visible{outline:2px solid var(--c-cyan);outline-offset:-2px;border-radius:var(--radius-sm)}.so-nav>li>a::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:2px;background:linear-gradient(90deg,var(--c-cyan),var(--c-magenta));transform:scaleX(0);transform-origin:center;transition:transform 0.2s ease}.so-nav>li:hover>a::after,.so-nav>li.so-has-mega:focus-within>a::after{transform:scaleX(1)}.so-nav>li.so-has-mega>a::before{content:'';order:2;width:8px;height:8px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);margin-left:4px;transition:transform 0.2s}.so-nav>li.so-has-mega:hover>a::before,.so-nav>li.so-has-mega:focus-within>a::before{transform:rotate(-135deg) translateY(0)}.so-mega{position:absolute;left:0;right:0;top:100%;background:var(--n-0);border-top:1px solid var(--n-200);border-bottom:1px solid var(--n-200);box-shadow:0 16px 48px rgba(0,0,0,0.08);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity 0.18s ease,transform 0.18s ease,visibility 0.18s;z-index:99;padding:0}.so-mega-inner{max-width:1320px;margin:0 auto;padding:32px 32px;display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:6px 24px}.so-mega-inner>.so-mega-featured{grid-column:4}.so-nav>li.so-has-mega:hover>.so-mega,.so-nav>li.so-has-mega:focus-within>.so-mega,.so-nav>li.so-has-mega[data-open="true"]>.so-mega{opacity:1;visibility:visible;transform:translateY(0)}.so-nav>li.so-has-mega>a::after{}.so-mega::before{content:'';position:absolute;top:-12px;left:0;right:0;height:12px}.so-mega-col .so-mega-heading{display:block;font-family:var(--font-mono);font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--n-700);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--n-200)}.so-mega-col ul{list-style:none;margin:0;padding:0}.so-mega-col li{margin-bottom:2px}.so-mega-col a{display:block;padding:6px 10px;margin:0 -10px;border-radius:var(--radius-sm);text-decoration:none;color:var(--n-900);font-size:0.875rem;font-weight:500;transition:all 0.12s ease;position:relative}.so-mega-col a small{display:block;color:var(--n-500);font-weight:400;font-size:0.8125rem;margin-top:2px;transition:color 0.12s}.so-mega-col a:hover{background:var(--c-cyan-soft);color:var(--c-key);transform:translateX(2px)}.so-mega-col a:hover small{color:var(--n-700)}.so-mega-featured{background:linear-gradient(135deg,var(--n-900) 0%,var(--c-key-soft) 100%);color:white;border-radius:var(--radius-lg);padding:24px;position:relative;overflow:hidden}.so-mega-featured::before{content:'';position:absolute;top:-40%;right:-20%;width:200px;height:200px;background:radial-gradient(circle,var(--c-magenta) 0%,transparent 60%);opacity:0.4}.so-mega-featured::after{content:'';position:absolute;bottom:-30%;left:-10%;width:160px;height:160px;background:radial-gradient(circle,var(--c-cyan) 0%,transparent 60%);opacity:0.3}.so-mega-featured .so-mega-heading{display:block;font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:white;text-transform:none;letter-spacing:-0.01em;border-bottom:none;padding-bottom:0;margin:0 0 12px;position:relative;z-index:1;line-height:1.3}.so-mega-featured p{font-size:0.875rem;line-height:1.5;color:rgba(255,255,255,0.85);margin:0 0 20px;position:relative;z-index:1}.so-mega-cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 18px;background:white;color:var(--n-900);font-family:var(--font-display);font-size:0.9375rem;font-weight:600;text-decoration:none;border-radius:var(--radius-md);position:relative;z-index:1;transition:background 0.15s,transform 0.15s}.so-mega-cta-btn:hover,.so-mega-cta-btn:focus-visible{background:var(--c-yellow);color:var(--n-900);transform:translateY(-1px)}.so-mega-cta-btn:focus-visible{outline:2px solid var(--c-cyan);outline-offset:2px}@media (max-width:900px){.so-nav{display:none}.so-nav-mobile-open .so-nav{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;max-height:calc(100dvh - 200px);background:var(--n-0);overflow-y:auto;padding:8px 0 24px;z-index:99;border-top:1px solid var(--n-200);box-shadow:0 18px 40px rgba(0,0,0,.14)}.so-nav>li>a{padding:16px 24px;font-size:1.0625rem;justify-content:space-between}.so-nav>li>a::after{display:none}.so-mega{position:static;box-shadow:none;border:none;background:var(--n-50);opacity:1;visibility:visible;transform:none;display:none;transition:none}.so-nav>li.so-has-mega[data-open="true"]>.so-mega{display:block}.so-nav>li.so-has-mega:hover>.so-mega{opacity:1;visibility:visible;transform:none}.so-mega-inner{grid-template-columns:1fr;padding:16px 24px;gap:20px}.so-mega-featured{order:99}.so-burger{display:flex;background:none;border:none;padding:8px;cursor:pointer;flex-direction:column;gap:4px}.so-burger span{display:block;width:22px;height:2px;background:var(--n-900);transition:transform 0.2s,opacity 0.2s}.so-nav-mobile-open .so-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}.so-nav-mobile-open .so-burger span:nth-child(2){opacity:0}.so-nav-mobile-open .so-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}}@media (min-width:901px){.so-burger{display:none}}
@media (max-width:900px){.so-header{-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff}.so-header-inner{flex-direction:column;align-items:center;gap:8px}.so-logo{justify-content:center}.so-header-actions{flex-direction:column;align-items:center;gap:0;width:auto}.so-burger{margin:0 auto}.so-header .so-btn-primary{position:fixed;left:0;right:0;bottom:0;border-radius:0;justify-content:center;text-align:center;padding:15px 16px;font-size:1.0625rem;z-index:120;box-shadow:0 -4px 18px rgba(0,0,0,.16)}body{padding-bottom:60px}.so-nav-mobile-open .so-nav{height:calc(100dvh - 200px);max-height:none;padding-bottom:80px}}

.so-logo-img{height:38px;width:auto;display:block}.so-logo-mark{display:none!important}@media(max-width:900px){.so-logo-img{height:34px}}

/* assets/css/regionen-menu.css */
/* ===========================================================================
   regionen-menu.css  ·  seooptimierung.de (astra-child)
   Regionen-Mega-Menue OHNE JavaScript (native <details>/<summary>):
     - Desktop: Service-Tabs (Reihe) + Bundesland-Rail (links) + Orts-Panel (rechts)
     - Mobile:  verschachteltes Akkordeon (Service -> Bundesland -> Orte)
   Scope ausschliesslich .so-mega--regionen.
   =========================================================================== */

/* Lesbarer, AA-konformer Link-Blau-Ton fuer die Orts-Links (Hover heller). */
.so-mega--regionen { --so-rm-link: #b91c1c; }

/* <summary>-Standardmarker entfernen */
.so-mega--regionen summary { list-style: none; cursor: pointer; }
.so-mega--regionen summary::-webkit-details-marker { display: none; }
.so-mega--regionen summary:focus-visible,
.so-mega--regionen .so-rm-cities a:focus-visible,
.so-mega--regionen .so-rm-all:focus-visible {
  outline: 2px solid var(--c-cyan);
  outline-offset: 2px;
  border-radius: 6px;
}

.so-mega--regionen .so-mega-inner {
  display: block;
  grid-template-columns: none;
  max-width: none;
  margin: 0;
  padding: 0;
}

/* =====================  DESKTOP (Tabs + Rail + Panel)  ===================== */
@media (min-width: 881px) {
  .so-regionen-mega {
    position: relative;
    min-height: 648px;            /* fasst auch das groesste Bundesland (BW, 60 Orte / 3 Spalten) */
    padding-top: 56px;            /* Platz fuer die Service-Tab-Reihe */
  }

  /* Service-<details> schweben als Tabs nebeneinander (Body ist absolut). */
  .so-mega--regionen .so-rm-svc {
    position: static;
    float: left;
  }
  .so-mega--regionen .so-rm-tab {
    display: inline-flex;
    align-items: center;
    margin: 7px 6px 0 0;
    padding: 9px 16px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-family: var(--font-sans);
    font-size: 14px;
    color: var(--n-600);
    white-space: nowrap;
    transition: background .12s ease, color .12s ease, border-color .12s ease;
  }
  .so-mega--regionen .so-rm-tab:hover { background: var(--n-50); color: var(--n-900); }
  .so-mega--regionen .so-rm-svc[open] > .so-rm-tab {
    color: var(--c-cyan);
    border-color: var(--c-cyan);
    background: var(--c-cyan-soft);
    font-weight: 600;
  }
  .so-mega--regionen .so-rm-svc:first-of-type { margin-left: clamp(16px, 1.6vw, 36px); }

  /* Tab-Reihe vom Inhalt trennen */
  .so-regionen-mega::before {
    content: "";
    position: absolute;
    top: 56px; left: 0; right: 0;
    border-top: 1px solid var(--n-200);
  }

  /* Body des offenen Service: absolut unter der Tab-Reihe, volle Breite. */
  .so-mega--regionen .so-rm-body {
    position: absolute;
    top: 57px; left: 0; right: 0; bottom: 5px;   /* 5px Luft am unteren Submenue-Rand */
    overflow: hidden;
  }
  .so-mega--regionen .so-rm-groups {
    position: relative;
    min-height: 100%;
  }

  /* Bundesland-<details> bilden die linke Rail (Pane ist absolut rechts). */
  .so-mega--regionen .so-rm-group {
    width: 232px;
    border-left: 3px solid transparent;
  }
  .so-mega--regionen .so-rm-group[open] {
    border-left-color: var(--c-cyan);
    background: var(--c-cyan-soft);
  }
  .so-mega--regionen .so-rm-state {
    display: flex;
    align-items: center;
    padding: 9px 16px 9px 14px;
    font-family: var(--font-sans);
    font-size: 14px;
    color: var(--n-700);
    transition: background .12s ease, color .12s ease;
  }
  .so-mega--regionen .so-rm-group:not([open]) > .so-rm-state:hover { background: var(--n-50); }
  .so-mega--regionen .so-rm-group[open] > .so-rm-state { color: var(--c-cyan); font-weight: 600; }
  .so-mega--regionen .so-rm-chevron { display: none; }   /* Rail markiert per Highlight */

  /* Orts-Panel rechts neben der Rail */
  .so-mega--regionen .so-rm-pane {
    position: absolute;
    top: 0; left: 256px; right: 28px;
    padding: 22px 0 22px 28px;
    border-left: 1px solid var(--n-200);
  }
  .so-mega--regionen .so-rm-cities { column-count: 4; column-gap: 22px; }
}

/* =====================  Gemeinsame Panel-Innereien  ======================= */
.so-mega--regionen .so-rm-pane-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--n-100);
}
.so-mega--regionen .so-rm-pane-title { font-size: 15px; font-weight: 600; color: var(--n-900); }
.so-mega--regionen .so-rm-all {
  flex: 0 0 auto;
  font-size: 13px; font-weight: 600;
  color: var(--c-magenta); text-decoration: none; white-space: nowrap;
}
.so-mega--regionen .so-rm-all:hover { text-decoration: underline; }

.so-mega--regionen .so-rm-cities { list-style: none; margin: 0; padding: 0; }
.so-mega--regionen .so-rm-cities li { break-inside: avoid; }
.so-mega--regionen .so-rm-cities a {
  display: block;
  padding: 4px 0;
  font-size: 13.5px;
  line-height: 1.35;
  color: var(--so-rm-link);
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color .1s ease;
}
.so-mega--regionen .so-rm-cities a:hover { color: var(--c-cyan); text-decoration: underline; }

/* =====================  MOBILE (verschachteltes Akkordeon)  =============== */
@media (max-width: 880px) {
  .so-mega--regionen .so-rm-svc { border-top: 1px solid var(--n-200); }
  .so-mega--regionen .so-rm-svc:first-of-type { border-top: 0; }
  .so-mega--regionen .so-rm-tab {
    display: flex;
    align-items: center;
    padding: 15px 16px;
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 600;
    color: var(--n-900);
  }
  .so-mega--regionen .so-rm-svc[open] > .so-rm-tab { color: var(--c-cyan); }

  .so-mega--regionen .so-rm-body { background: var(--n-50); }
  .so-mega--regionen .so-rm-group { border-top: 1px solid var(--n-200); }
  .so-mega--regionen .so-rm-state {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 13px 18px;
    font-family: var(--font-sans);
    font-size: 15px;
    color: var(--n-800);
  }
  .so-mega--regionen .so-rm-group[open] > .so-rm-state { color: var(--c-cyan); font-weight: 600; }

  .so-mega--regionen .so-rm-chevron {
    width: 8px; height: 8px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
    transition: transform .15s ease;
    margin-left: 12px;
    color: var(--n-500);
  }
  .so-mega--regionen .so-rm-group[open] > .so-rm-state .so-rm-chevron {
    transform: rotate(-135deg);
    color: var(--c-cyan);
  }

  .so-mega--regionen .so-rm-pane { padding: 2px 18px 14px; }
  .so-mega--regionen .so-rm-pane-head { margin-bottom: 10px; padding-bottom: 8px; }
  .so-mega--regionen .so-rm-pane-title { display: none; }   /* Bundesland steht schon im Kopf */
  .so-mega--regionen .so-rm-cities a { padding: 9px 0; font-size: 14.5px; border-top: 1px solid var(--n-200); }
  .so-mega--regionen .so-rm-cities li:first-child a { border-top: 0; }
}

/* assets/css/author.css */
/* ===========================================================================
   author.css  ·  seooptimierung.de (astra-child)
   Autorenbox (redaktionell + „geprüft von") und Autoren-Foto auf der Bio-Seite.
   Nutzt die Theme-Tokens (--n-*, --c-cyan, --c-magenta, --radius-lg, --font-mono).
   =========================================================================== */
.so-author-box{display:flex;gap:16px;align-items:flex-start;margin:36px 0;padding:20px;
  border:1px solid var(--n-200);border-radius:var(--radius-lg);background:var(--n-50)}
.so-author-photo{flex:0 0 auto;border-radius:999px;object-fit:cover}
.so-author-kicker{display:block;font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--n-500);font-family:var(--font-mono)}
.so-author-name{font-size:16px;font-weight:600;color:var(--n-900);text-decoration:none}
.so-author-name:hover{color:var(--c-cyan)}
.so-author-role{display:block;font-size:13px;color:var(--c-cyan);margin-bottom:6px}
.so-author-bio{font-size:13.5px;color:var(--n-700);margin:6px 0 10px;line-height:1.5}
.so-author-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.so-author-chips span{font-size:11.5px;color:var(--n-700);border:1px solid var(--n-200);
  border-radius:999px;padding:3px 10px}

/* Social-Icons: klare, gleich große Buttons mit Abstand (statt gequetschter Inline-Links) */
.so-author-social{display:flex;flex-wrap:wrap;gap:10px;margin:2px 0 14px}
.so-author-social-link{display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;flex:0 0 auto;border:1px solid var(--n-200);border-radius:10px;
  background:#fff;color:var(--n-600);text-decoration:none;
  transition:color .15s ease,border-color .15s ease,background .15s ease}
.so-author-social-link:hover,.so-author-social-link:focus-visible{
  color:var(--c-magenta);border-color:var(--c-magenta);background:var(--n-50)}
.so-author-social-link svg{width:18px;height:18px;display:block}

.so-author-link{display:inline-block;font-size:13px;font-weight:600;color:var(--c-magenta);text-decoration:none}
.so-author-link:hover{text-decoration:underline}
.so-author-box--review{align-items:center}
.so-author-figure{margin:0 0 24px}
.so-author-figure img{border-radius:var(--radius-lg);max-width:160px;height:auto}
@media (max-width:600px){.so-author-box{flex-direction:column}}

/* A11y-Kontrast (Lighthouse): Autorenbox-Text muss AA erfüllen. Die generische
   Prose-Linkfarbe (.so-prose a = #d62828 ~4,4:1) und das helle Cyan der Rolle
   (#d62828 ~2,5:1) fielen durch. Höher spezifiziert, damit es die Prose-Regel
   sticht, mit AA-sicheren Werten auf dem hellen Box-Hintergrund (--n-50). */
.so-author-box a.so-author-name{color:var(--n-900)}
.so-author-box .so-author-role{color:#b91c1c}   /* dunkles Teal statt --c-cyan */
.so-author-box a.so-author-link{color:#d62828}  /* dunkles Magenta statt --c-magenta */

/* assets/css/fairuse-bar.css */
/* Fair-Use-Garantie Trust-Bar (Header, nicht sticky) */
.so-fairuse{background:var(--c-yellow-soft,#fbeaea);border-bottom:1px solid #f7d4d4}
.so-fairuse-inner{max-width:var(--container,1200px);margin:0 auto;padding:8px 52px 8px 20px;
  display:flex;align-items:center;justify-content:center;gap:10px;position:relative}
.so-fairuse-ic{display:inline-flex;flex:0 0 auto;color:#b91c1c}
.so-fairuse-txt{margin:0;font-size:13px;line-height:1.35;color:#b91c1c;text-align:center}
.so-fairuse-txt strong{font-weight:800}
.so-fairuse-dismiss{position:absolute;right:8px;top:50%;transform:translateY(-50%);margin:0;padding:0;border:0;line-height:0}
.so-fairuse-x{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;
  border:0;background:transparent;color:#b91c1c;cursor:pointer;border-radius:6px;line-height:0;padding:0}
.so-fairuse-x:hover{background:rgba(214,40,40,.10)}
.so-fairuse-x:focus-visible{outline:2px solid #b91c1c;outline-offset:2px}
@media (max-width:600px){
  .so-fairuse-inner{justify-content:flex-start;padding-right:48px}
  .so-fairuse-txt{font-size:12px;text-align:left}
}

/* assets/css/so-fixes.css */
/* =============================================================================
   so-fixes.css · seooptimierung.de (astra-child)
   Nachträgliche Korrekturen:
     1) CTA-Banner – zweiter <span> als Subtitle statt zweitem Button
     2) Breadcrumbs auf Einzel-Blogposts (Optik)
     3) Blog-Übersicht – gleichmäßige Karten, Platzhalter bei fehlendem Bild
   ============================================================================= */

/* ── 1) CTA-Banner: Button mit Subtitle ───────────────────────────────────── */
.so-cta-band .so-btn-primary,
.so-cta-inner .so-btn-primary,
.so-cta-band-content .so-btn-primary {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  line-height: 1.25;
  text-align: center;
  white-space: normal;
}
.so-cta-band .so-btn-primary > span:first-child,
.so-cta-band-content .so-btn-primary > span:first-child {
  font-weight: 700;
  font-size: 1.02rem;
}
.so-cta-band .so-btn-primary > span:last-child:not(:first-child),
.so-cta-band-content .so-btn-primary > span:last-child:not(:first-child) {
  font-weight: 500;
  font-size: 0.8rem;
  letter-spacing: .01em;
  opacity: .82;
  background: none;        /* falls Theme dem span einen eigenen Button-Hintergrund gibt */
  padding: 0;
  border: 0;
}

/* ── 2) Breadcrumbs auf Einzel-Blogposts ──────────────────────────────────── */
.so-bc {
  max-width: var(--container, 1200px);
  margin: 0 auto 1.2rem;
  padding: 0 20px;
  font-size: 13px;
  line-height: 1.4;
  color: var(--n-500, #555555);
}
.so-bc a { color: var(--n-600, #555555); text-decoration: none; }
.so-bc a:hover { color: var(--c-magenta, #d62828); }
.so-bc .separator { margin: 0 .4em; color: var(--n-300, #e6e6e6); }
.so-bc p { margin: 0; }

/* ── 3) Blog-Übersicht: saubere, gleich hohe Karten ───────────────────────── */
.blog .site-main .ast-row,
.archive .site-main .ast-row,
.search-results .site-main .ast-row {
  gap: 28px;
}

.blog .site-main article.ast-article-post,
.archive .site-main article.ast-article-post,
.search-results .site-main article.ast-article-post {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--n-150, #f8f8f8);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
  transition: box-shadow .2s ease, transform .2s ease;
  margin-bottom: 28px;
}
.blog .site-main article.ast-article-post:hover,
.archive .site-main article.ast-article-post:hover {
  box-shadow: 0 10px 28px rgba(16, 24, 40, .09);
  transform: translateY(-2px);
}

/* Einheitliches Titelbild-Verhältnis */
.blog .ast-article-post .post-thumb img,
.blog .ast-article-post .ast-blog-featured-section img,
.archive .ast-article-post .post-thumb img,
.archive .ast-article-post .ast-blog-featured-section img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
}

/* Platzhalter-Verlauf, wenn ein Beitrag KEIN Titelbild hat → keine leere Fläche */
.blog .ast-article-post:not(.ast-article-image):not(.has-post-thumbnail) .ast-article-inner::before,
.archive .ast-article-post:not(.ast-article-image):not(.has-post-thumbnail) .ast-article-inner::before {
  content: "";
  display: block;
  height: 8px;
  background: linear-gradient(90deg, var(--c-cyan, #d62828), var(--c-magenta, #d62828) 55%, var(--c-yellow, #d62828));
}

/* Innenabstand & Typo der Karten */
.blog .ast-article-post .ast-article-inner,
.archive .ast-article-post .ast-article-inner,
.search-results .ast-article-post .ast-article-inner {
  padding: 22px 24px 26px;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}
.blog .ast-article-post .entry-title,
.archive .ast-article-post .entry-title {
  font-size: 1.18rem;
  line-height: 1.3;
  margin: .35rem 0 .5rem;
}
.blog .ast-article-post .ast-excerpt-container,
.archive .ast-article-post .ast-excerpt-container {
  color: var(--n-600, #555555);
  flex: 1 1 auto;
}
.blog .ast-article-post .read-more,
.archive .ast-article-post .read-more { margin-top: 14px; }

/* Archiv-Kopf (z. B. „Blog“) etwas luftiger */
.blog .ast-archive-description,
.archive .ast-archive-description {
  max-width: var(--container, 1200px);
  margin: 0 auto 1.5rem;
  padding: 0 20px;
}

/* ── 4) Sticky-Sidebar absichern: Astra-Wrapper dürfen das Kleben nicht brechen ─ */
.single .ast-container, .page .ast-container,
.single #primary, .page #primary,
.single .site-content, .page .site-content,
.single .entry-content, .page .entry-content { overflow: visible; }
.so-with-sidebar { align-items: start; }
.so-sidebar { position: sticky; top: 100px; align-self: start; }

/* ── 4) Kompakte Trust-Bar (Zahlen nebeneinander, klein & sauber) ──────────── */
.so-trustbar {
  max-width: var(--container, 1200px);
  margin: -0.5rem auto 2.5rem;
  padding: 0 20px;
}
.so-trustbar-inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0;
  background: linear-gradient(180deg, #fff, var(--n-50, #f8f8f8));
  border: 1px solid var(--n-150, #f8f8f8);
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(16, 24, 40, .04);
  overflow: hidden;
}
.so-trustbar-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 16px 22px;
  border-left: 1px solid var(--n-150, #f8f8f8);
}
.so-trustbar-item:first-child { border-left: 0; }
.so-trustbar-item .num {
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.05;
  background: linear-gradient(90deg, var(--c-cyan, #d62828), var(--c-magenta, #d62828));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.so-trustbar-item .lbl {
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--n-500, #555555);
  line-height: 1.25;
}
@media (max-width: 600px) {
  .so-trustbar-item { border-left: 0; border-top: 1px solid var(--n-150, #f8f8f8); }
  .so-trustbar-item:first-child { border-top: 0; }
}

/* ── 5) A11y: Fließtext-Links unterstreichen (axe: link-in-text-block) ───────
   Inline-Links im Content müssen auch ohne Farbe erkennbar sein. Die bestehende
   Regel in design-system.css deckt nur `p a` / `li a` ab — Links in Tabellen,
   <div>s, Blockquotes etc. blieben offen. Diese Regel greift JEDEN klassen-losen
   Link in den Content-Containern; Komponenten mit eigener Klasse (Buttons,
   Cards, CTAs, Sidebar-Nav) tragen eine Klasse und bleiben damit ausgenommen. */
.entry-content a:not([class]),
.so-prose a:not([class]),
.so-section a:not([class]) {
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

/* assets/css/seo-pages.css */
/* ════════════════════════════════════════════════════════════════════════
   seooptimierung.de — KOMPLETTES Landingpage-Stylesheet
   Deckt ALLE so-* Klassen ab (Hero, Trust-Bars in allen Varianten,
   Sidebar, Hubs, Buttons, CTA-Bänder, FAQ, Tabellen, Grids …).
   Marke: Pink/Magenta (Discovery-Button-Ton).

   → Früher im Customizer unter „Zusätzliches CSS". Jetzt als Theme-Datei
     eingebunden (functions.php, soc_enqueue_seo_pages, lädt zuletzt).
   ════════════════════════════════════════════════════════════════════════ */

:root{
  --so-accent:var(--primary,#D62828);
  --so-accent-dark:var(--primary-hover,#B91C1C);
  --so-accent-grad:var(--primary,#D62828);
  --so-ink:var(--text,#1E1E1E);
  --so-body:var(--text-light,#555555);
  --so-muted:var(--text-light,#555555);
  --so-line:var(--border,#E6E6E6);
  --so-bg-soft:var(--surface,#F8F8F8);
  --so-radius:14px;
  --so-shadow:0 8px 28px rgba(0,0,0,.08);
}

/* ───────────────────────── Grund-Layout ───────────────────────── */
.so-section{padding:3rem 0}
.so-section-inner{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.so-prose{max-width:760px;margin:0 auto;padding:0 1.25rem;
  font-size:1.05rem;line-height:1.7;color:var(--so-body)}
.so-prose h2{font-size:1.7rem;line-height:1.25;color:var(--so-ink);
  margin:2.4rem 0 .9rem;font-weight:800;letter-spacing:-.01em}
.so-prose h3{font-size:1.25rem;color:var(--so-ink);margin:1.8rem 0 .6rem;font-weight:700}
.so-prose p{margin:0 0 1.1rem}
.so-prose a{color:var(--so-accent);text-decoration:underline;text-underline-offset:2px}
.so-prose a:hover{color:var(--so-accent-dark)}
.so-prose ul,.so-prose ol{margin:0 0 1.2rem;padding-left:1.3rem}
.so-prose li{margin:.4rem 0}
.so-section-eyebrow,.so-hero-eyebrow{display:inline-block;font-size:.78rem;
  font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--so-accent);margin-bottom:.6rem}
.so-section-lede{font-size:1.15rem;color:var(--so-muted);max-width:620px;margin:0 0 1.8rem}

/* ───────────────────────── Buttons ───────────────────────── */
.so-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.85rem 1.6rem;border-radius:9px;font-weight:700;font-size:1rem;
  text-decoration:none;cursor:pointer;border:2px solid transparent;
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease;
  line-height:1.2;text-align:center}
.so-btn-primary{background:var(--so-accent);color:#fff;border-color:var(--so-accent)}
.so-btn-primary:hover{background:var(--so-accent-dark);border-color:var(--so-accent-dark);
  color:#fff;transform:translateY(-1px);box-shadow:0 8px 20px rgba(214,40,40,.28)}
.so-btn-secondary{background:#fff;color:var(--so-ink);border-color:var(--so-line)}
.so-btn-secondary:hover{border-color:var(--so-accent);color:var(--so-accent);transform:translateY(-1px)}

/* ───────────────────────── Hero ───────────────────────── */
.so-hero{max-width:1180px;margin:0 auto;padding:3.2rem 1.25rem 2.4rem;
  display:grid;grid-template-columns:1.25fr .9fr;gap:2.5rem;align-items:center}
.so-hero > div:first-child{min-width:0}
.so-hero h1{font-size:2.6rem;line-height:1.12;letter-spacing:-.02em;
  color:var(--so-ink);margin:0 0 1rem;font-weight:800}
.so-hero h1 .accent{color:var(--so-accent)}
.so-hero-lede,.so-hero .so-lede{font-size:1.18rem;line-height:1.6;
  color:var(--so-muted);margin:0 0 1.6rem;max-width:600px}
.so-hero-ctas{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.6rem}
.so-hero-trust{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:.4rem}
.so-hero-trust-item{font-size:.92rem;color:var(--so-muted);font-weight:600;
  display:flex;align-items:center;gap:.4rem}
.so-hero-trust-item strong{color:var(--so-accent);font-size:1.05rem}
.so-hero-trust-item::before{content:"✓";color:var(--so-accent);font-weight:800}
.so-hero-trust-item strong + *::before,.so-hero-trust-item:has(strong)::before{content:none}
@media(max-width:880px){
  .so-hero{grid-template-columns:1fr;padding-top:2rem}
  .so-hero h1{font-size:2rem}
  .so-hero-visual{display:none}
}

/* Hero-Visual (Ranking-Karten, Startseite) */
.so-hero-visual{display:flex;flex-direction:column;gap:.6rem}
.so-visual-card{display:flex;align-items:center;gap:.8rem;background:#fff;
  border:1px solid var(--so-line);border-radius:10px;padding:.7rem .9rem;
  box-shadow:0 2px 8px rgba(0,0,0,.05)}
.so-visual-card.top{border-color:var(--so-accent);box-shadow:0 6px 18px rgba(214,40,40,.15)}
.so-visual-rank{font-weight:800;color:var(--so-muted);min-width:1.8rem}
.so-visual-rank.top-rank{color:var(--so-accent)}
.so-visual-bar{flex:1;height:8px;background:#f8f8f8;border-radius:99px;overflow:hidden}
.so-visual-bar-fill{height:100%;background:var(--so-accent);border-radius:99px}

/* ───────────────── Trust-Bars (ALLE Varianten) ───────────────── */
/* Gemeinsamer Balken-Container */
.so-trust-bar{max-width:1180px;margin:0 auto 1rem;padding:1.4rem 1.25rem;
  display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;justify-content:center;
  background:var(--so-bg-soft);border-top:1px solid var(--so-line);
  border-bottom:1px solid var(--so-line)}
.so-trust-inner{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;justify-content:center;
  align-items:center;width:100%}
.so-trust-stats,.so-trust-items{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;justify-content:center}
.so-trust-label{font-size:.85rem;color:var(--so-muted)}
.so-trust-bar-label{font-size:.85rem;color:var(--so-muted);margin-top:.15rem}

/* Variante mit eigenen Item-Boxen (Service- & Hero-Trust) */
.so-trust-bar-item,.so-trust-item{display:flex;flex-direction:column;
  align-items:center;text-align:center;gap:.15rem;min-width:120px}
/* Zahl in den diversen Schreibweisen */
.so-stat-number,.so-trust-bar-number,.so-trust-stat-num{
  font-size:1.7rem;font-weight:800;color:var(--so-accent);line-height:1.1}
.so-stat-label,.so-trust-stat-label{font-size:.85rem;color:var(--so-muted)}
.so-trust-icon{color:var(--so-accent);font-weight:800}
.so-trust-text{color:var(--so-body);font-size:.92rem}
/* Lauftext-Trust-Item (Hamburg „47.200+ aktive …") */
.so-trust-bar-item strong{color:var(--so-accent);font-weight:800}

/* ───────────────── Mit-Sidebar-Layout ───────────────── */
.so-with-sidebar{max-width:1180px;margin:0 auto;padding:0 1.25rem;
  display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:2.5rem;align-items:start}
.so-with-sidebar .so-prose{max-width:none;margin:0;padding:0}
@media(max-width:980px){
  .so-with-sidebar{grid-template-columns:1fr}
  .so-sidebar{order:2}
}

/* ───────────────── Sidebar ───────────────── */
.so-sidebar{display:flex;flex-direction:column;gap:1.25rem;position:sticky;top:1.5rem}
.so-sidebar-block{background:#fff;border:1px solid var(--so-line);
  border-radius:12px;padding:1.1rem 1.2rem}
.so-sidebar-block h3{font-size:.95rem;font-weight:700;color:var(--so-ink);
  margin:0 0 .7rem;text-transform:none}
.so-sidebar-block ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.so-sidebar-block li a{color:var(--so-body);text-decoration:none;font-size:.92rem;
  display:flex;flex-direction:column;line-height:1.35}
.so-sidebar-block li a:hover{color:var(--so-accent)}
.so-sidebar-block li a small{color:var(--so-muted);font-size:.78rem}
.so-sidebar-trust{background:var(--so-ink);border-color:var(--so-ink)}
.so-sidebar-trust h3,.so-sidebar-trust p{color:#fff}
.so-sidebar-trust p{font-size:.9rem;opacity:.85;margin:.4rem 0 .9rem}
.so-sidebar-cta{display:inline-flex;align-items:center;gap:.4rem;
  background:var(--so-accent);color:#fff;text-decoration:none;font-weight:700;
  padding:.7rem 1.1rem;border-radius:8px;font-size:.92rem}
.so-sidebar-cta:hover{background:var(--so-accent-dark);color:#fff}

/* ───────────────── Hub-Grids (Branchen / Plattformen / Regionen) ───────────────── */
.so-region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:.7rem;margin:1.1rem 0 2rem}
.so-region-grid a{display:block;padding:.8rem 1rem;background:#fff;
  border:1px solid var(--so-line);border-radius:10px;text-decoration:none;
  color:var(--so-ink);font-weight:600;font-size:.95rem;transition:all .12s ease}
.so-region-grid a:hover{border-color:var(--so-accent);color:var(--so-accent);
  transform:translateY(-1px);box-shadow:0 4px 14px rgba(214,40,40,.12)}

/* Service-/Karten-Grid (Startseite) */
.so-service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.2rem;margin:1.5rem 0}
.so-service-card{display:block;background:#fff;border:1px solid var(--so-line);
  border-radius:var(--so-radius);padding:1.5rem;text-decoration:none;
  color:var(--so-ink);transition:all .15s ease;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.so-service-card:hover{border-color:var(--so-accent);transform:translateY(-3px);
  box-shadow:var(--so-shadow)}
.so-service-card .icon{width:2.6rem;height:2.6rem;border-radius:10px;
  background:var(--so-accent-grad);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.so-service-card h3{margin:0 0 .5rem;font-size:1.15rem}
.so-service-card p{margin:0 0 .8rem;color:var(--so-muted);font-size:.93rem;line-height:1.55}
.so-service-card .link{color:var(--so-accent);font-weight:700;font-size:.9rem}

/* ───────────────── Stat-Box / Highlight / Steps / Tabelle / Checkliste ───────────────── */
.so-stat-box{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;
  background:var(--so-bg-soft);border-left:4px solid var(--so-accent);
  border-radius:10px;padding:1.3rem 1.6rem;margin:1.8rem 0}
.so-stat-box .so-stat-item{display:flex;flex-direction:column}
.so-stat-box .num{font-size:1.9rem;font-weight:800;color:var(--so-accent);line-height:1.1}
.so-stat-box .label{font-size:.9rem;color:var(--so-muted);margin-top:.3rem}

.so-highlight-card{background:#fff;border:1px solid var(--so-line);border-left:4px solid var(--so-accent);
  border-radius:12px;padding:1.2rem 1.4rem;margin:1.5rem 0;box-shadow:0 2px 10px rgba(0,0,0,.05)}
.so-highlight-card h3{margin:0 0 .4rem;font-size:1.1rem;color:var(--so-ink)}
.so-highlight-card p{margin:0;color:var(--so-body);font-size:.96rem}
.so-highlight-icon{font-size:1.6rem;line-height:1;flex-shrink:0}
.so-highlight-content strong{display:block;font-size:1.05rem;margin-bottom:.35rem;color:var(--so-ink)}

.so-process{display:flex;flex-direction:column;gap:.85rem;margin:1.75rem 0;counter-reset:so-step}
.so-step{display:flex;gap:1rem;align-items:flex-start;background:var(--so-bg-soft);
  border-radius:10px;padding:1rem 1.2rem}
.so-step strong{color:var(--so-ink)}
.so-step-num{flex-shrink:0;width:2.1rem;height:2.1rem;border-radius:50%;
  background:var(--so-accent);color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center}
.so-step-content strong{display:block;color:var(--so-ink);margin-bottom:.2rem}
.so-step-content p{margin:0;color:var(--so-muted);font-size:.93rem}
/* Variante OHNE so-step-num/so-step-content (Text direkt im so-step):
   automatischer Nummern-Kreis per Counter, damit die Optik konsistent bleibt */
.so-step:not(:has(.so-step-num)){counter-increment:so-step;padding-left:1.2rem}
.so-step:not(:has(.so-step-num))::before{content:counter(so-step);flex-shrink:0;
  width:2.1rem;height:2.1rem;border-radius:50%;background:var(--so-accent);color:#fff;
  font-weight:700;display:flex;align-items:center;justify-content:center;font-size:1rem}
.so-step:not(:has(.so-step-num)) strong{display:inline}

.so-compare-wrap{overflow-x:auto;margin:1.75rem 0}
.so-compare-table{width:100%;border-collapse:collapse;font-size:.94rem;margin:1.75rem 0}
.so-compare-table th,.so-compare-table td{text-align:left;padding:.8rem 1rem;
  border-bottom:1px solid var(--so-line);vertical-align:top}
.so-compare-table thead th{background:var(--so-bg-soft);color:var(--so-ink);
  font-weight:700;border-bottom:2px solid #e6e6e6}
.so-compare-table tbody tr:last-child td{border-bottom:none}

.so-checklist{list-style:none;padding:0;margin:1.5rem 0;display:grid;gap:.6rem}
.so-checklist li{position:relative;padding-left:1.9rem;color:var(--so-body)}
.so-checklist li::before{content:"✓";position:absolute;left:0;top:.05rem;
  width:1.3rem;height:1.3rem;border-radius:50%;background:rgba(214,40,40,.12);
  color:var(--so-accent);font-weight:700;font-size:.8rem;
  display:flex;align-items:center;justify-content:center}

/* ───────────────── Definition-Box / Experten-Tipp ───────────────── */
.so-definition-box{background:linear-gradient(135deg,#fdeaea 0%,#fbeaea 100%);
  border:1px solid #f7d4d4;border-radius:12px;padding:1.3rem 1.5rem;margin:1.8rem 0}
.so-definition-box h3{margin:0 0 .5rem;font-size:1.1rem;color:var(--so-accent-dark)}
.so-definition-box p{margin:0;color:var(--so-body)}
.so-expert-tip{background:#fdeaea;border:1px solid #f7d4d4;border-left:4px solid #f59e0b;
  border-radius:10px;padding:1.1rem 1.4rem;margin:1.6rem 0;color:#b91c1c;font-size:.97rem}
.so-expert-tip strong{color:#b91c1c}

/* ───────────────── FAQ ───────────────── */
.so-faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:2.5rem;align-items:start}
@media(max-width:880px){.so-faq-grid{grid-template-columns:1fr;gap:1.5rem}}
.so-faq,.so-faq-item{border:1px solid var(--so-line);border-radius:10px;
  padding:.4rem 1.1rem;margin:.6rem 0;background:#fff}
.so-faq summary,.so-faq-item summary{font-weight:700;color:var(--so-ink);
  cursor:pointer;padding:.7rem 0;list-style:none;position:relative;padding-right:1.6rem}
.so-faq summary::-webkit-details-marker,.so-faq-item summary::-webkit-details-marker{display:none}
.so-faq summary::after,.so-faq-item summary::after{content:"+";position:absolute;
  right:0;top:.6rem;font-size:1.3rem;color:var(--so-accent);font-weight:400}
.so-faq[open] summary::after,.so-faq-item[open] summary::after{content:"–"}
.so-faq p,.so-faq-item p{margin:0 0 .8rem;color:var(--so-body);font-size:.95rem;line-height:1.6}

/* ───────────────── CTA-Band ───────────────── */
.so-cta-band{background:var(--so-accent-grad);margin:3rem 0 0;padding:3rem 1.25rem}
.so-cta-inner,.so-cta-band-content{max-width:900px;margin:0 auto;text-align:center;color:#fff}
.so-cta-inner h2,.so-cta-band-content h2{color:#fff;font-size:2rem;margin:0 0 .8rem;font-weight:800}
.so-cta-inner p,.so-cta-band-content p,.so-cta-sub{color:#fff;opacity:.95;
  font-size:1.1rem;margin:0 0 1.6rem;line-height:1.55}
/* Button im pinken Band: weiß auf Pink, NICHT gelb */
.so-cta-band .so-btn-primary{background:#fff;color:var(--so-accent);border-color:#fff}
.so-cta-band .so-btn-primary:hover{background:var(--so-ink);color:#fff;border-color:var(--so-ink)}
.so-inline-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--so-accent);
  color:#fff;text-decoration:none;font-weight:700;padding:.85rem 1.6rem;border-radius:9px;margin:1rem 0}
.so-inline-cta:hover{background:var(--so-accent-dark);color:#fff}

/* ───────────────── Breadcrumbs ───────────────── */
.so-breadcrumbs{max-width:1180px;margin:0 auto;padding:1.1rem 1.25rem .2rem;
  font-size:.85rem;color:var(--so-muted);
  display:flex;flex-wrap:wrap;align-items:center;gap:.1rem;line-height:1.4}
.so-breadcrumbs span[property="itemListElement"]{display:inline-flex;align-items:center}
.so-breadcrumbs a{color:var(--so-muted);text-decoration:none;display:inline}
.so-breadcrumbs a:hover{color:var(--so-accent)}
.so-breadcrumbs .sep{margin:0 .5rem;color:#e6e6e6;display:inline}
.so-breadcrumbs .current{color:var(--so-ink);font-weight:600;display:inline}
.so-breadcrumbs meta{display:none}

/* ───────────────── Logo-Wall / Referenz / GEO-Slot ───────────────── */
.so-logo-grid,.so-trust-logo-section{display:flex;flex-wrap:wrap;gap:1.5rem;
  align-items:center;justify-content:center;margin:1.5rem 0;opacity:.7}
.so-logo-placeholder{padding:.4rem 1rem;background:var(--so-bg-soft);
  border-radius:6px;color:var(--so-muted);font-weight:600;font-size:.85rem}
.so-reference-line{display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline;
  justify-content:center;padding:.85rem 1.25rem;margin:0 auto;max-width:960px;
  font-size:.92rem;color:var(--so-muted);border-top:1px solid var(--so-line)}
.so-reference-label{font-weight:600;color:var(--so-body)}
.so-geo-slot{margin:1.5rem 0}

/* ───────────────── Mobile-Feinschliff ───────────────── */
@media(max-width:560px){
  .so-hero h1{font-size:1.7rem}
  .so-prose h2{font-size:1.4rem}
  .so-cta-inner h2,.so-cta-band-content h2{font-size:1.5rem}
  .so-btn{width:100%}
  .so-hero-ctas{flex-direction:column}
}

/* ───────────────── Ergänzungen: seltene Varianten ───────────────── */
.so-eyebrow{display:inline-block;font-size:.78rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;color:var(--so-accent);margin-bottom:.5rem}
.so-hero-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:2.5rem;align-items:center}
@media(max-width:880px){.so-hero-grid{grid-template-columns:1fr}}
.so-hero-card{background:#fff;border:1px solid var(--so-line);border-radius:14px;
  padding:1.5rem;box-shadow:var(--so-shadow)}
.so-hero-card h3{margin:0 0 .75rem;font-size:1.05rem}
.so-expert-tip-icon{font-size:1.3rem;margin-right:.4rem}
.so-faq-head{margin-bottom:1rem}
.so-reference-names{letter-spacing:.02em}
.so-map-embed{width:100%;border:0;border-radius:12px;margin:1.5rem 0;min-height:320px}
.so-map-caption{font-size:.85rem;color:var(--so-muted);text-align:center;margin-top:-.8rem}

/* ── Mid-prose CTA card (SEO-Malta.com) ───────────────────────────── */
.so-prose-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;
  gap:1rem 1.4rem;margin:2.2rem 0;padding:1.4rem 1.6rem;background:var(--so-bg-soft);
  border:1px solid var(--so-line);border-left:4px solid var(--so-accent);border-radius:14px}
.so-prose-cta p{margin:0;font-weight:700;color:var(--so-ink);font-size:1.08rem;line-height:1.4;flex:1 1 260px}
.so-prose-cta .so-btn{white-space:nowrap}
@media(max-width:560px){.so-prose-cta{flex-direction:column;align-items:stretch;text-align:center}}

/* ═══ Homepage refinements (SEO-Malta.com) ═══════════════════════════ */
/* 1) Trust bar: force label + all stat cards onto a single row */
.so-trust-bar{display:block !important}
.so-trust-bar .so-trust-inner{display:flex !important;flex-wrap:nowrap;align-items:center;
  justify-content:flex-start;gap:1.5rem 2rem;max-width:1180px;margin:0 auto}
.so-trust-bar .so-trust-stats{display:flex !important;flex-wrap:nowrap;gap:1rem;flex:1 1 auto}
.so-trust-bar .so-trust-stats>div{flex:1 1 0;min-width:0}
@media(max-width:900px){
  .so-trust-bar .so-trust-inner{flex-wrap:wrap}
  .so-trust-bar .so-trust-stats{flex-wrap:wrap}
}

/* 2) Sidebar "free audit" CTA: white button, red text → hover black */
.so-sidebar-trust .so-sidebar-cta,
.so-sidebar-trust a.so-sidebar-cta{background:#fff !important;color:var(--so-accent,#d62828) !important}
.so-sidebar-trust .so-sidebar-cta:hover,
.so-sidebar-trust .so-sidebar-cta:focus-visible,
.so-sidebar-trust a.so-sidebar-cta:hover{background:var(--so-ink,#1e1e1e) !important;
  color:#fff !important;transform:translateY(-2px)}

/* 3) Bottom CTA band button: white button, red text → hover black
      (must beat the header's `.so-btn-primary{color:#fff !important}`) */
.so-cta-band a.so-btn-primary,
.so-cta-inner a.so-btn-primary,
.so-cta-band-content a.so-btn-primary,
.so-cta-band .so-btn-primary,
.so-cta-inner .so-btn-primary{background:#fff !important;color:var(--so-accent,#d62828) !important;
  border-color:#fff !important}
.so-cta-band a.so-btn-primary:hover,
.so-cta-band a.so-btn-primary:focus,
.so-cta-inner a.so-btn-primary:hover,
.so-cta-band-content a.so-btn-primary:hover,
.so-cta-band .so-btn-primary:hover,
.so-cta-inner .so-btn-primary:hover{background:var(--so-ink,#1e1e1e) !important;
  color:#fff !important;border-color:var(--so-ink,#1e1e1e) !important}
