.cp-ortho-page { --ortho-accent: #059669; --ortho-dark: #047857; --ortho-soft: #ecfdf5; }
.cp-ortho-page .cp-hero { background: linear-gradient(135deg, #047857 0%, #059669 48%, #34d399 100%); position: relative; overflow: hidden; }
.cp-ortho-motion-bg { position: absolute; inset: 0; opacity: 0.1; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40' viewBox='0 0 80 40'%3E%3Cpath d='M0 30 L20 10 L40 25 L60 5 L80 20' fill='none' stroke='white' stroke-width='2'/%3E%3C/svg%3E"); background-size: 80px 40px; background-repeat: repeat-x; background-position: 0 70%; pointer-events: none; }
.cp-ortho-hero-panel { background: rgba(255,255,255,0.97); border-radius: 20px; padding: 1.5rem; box-shadow: 0 24px 60px rgba(0,0,0,0.15); }
.cp-ortho-joint-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 0.75rem; margin-bottom: 1rem; }
.cp-ortho-joint-stat { text-align: center; padding: 0.65rem 0.5rem; background: var(--ortho-soft); border-radius: 12px; border: 1px solid #a7f3d0; }
.cp-ortho-joint-stat strong { display: block; font-size: 1.1rem; color: var(--ortho-accent); line-height: 1.2; }
.cp-ortho-joint-stat span { font-size: 0.6875rem; color: #64748b; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.cp-ortho-alert { background: linear-gradient(90deg, #ecfdf5, #fff); border-left: 4px solid var(--ortho-accent); border-radius: 0 12px 12px 0; padding: 1.25rem 1.5rem; }
.cp-ortho-alert ul { margin: 0; padding-left: 1.1rem; }
.cp-ortho-alert li { margin-bottom: 0.35rem; color: #047857; font-weight: 500; }
.cp-ortho-service-card { border-top: 3px solid var(--ortho-accent); height: 100%; }
.cp-ortho-service-card .cp-service-icon { background: var(--ortho-accent) !important; }
.cp-ortho-pillar { border: 1px solid #a7f3d0; border-radius: 16px; padding: 1.25rem; height: 100%; background: linear-gradient(180deg, #ecfdf5 0%, #fff 60%); }
.cp-ortho-pillar-icon { width: 44px; height: 44px; border-radius: 12px; background: var(--ortho-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; margin-bottom: 0.75rem; }
.cp-ortho-package { border: 2px solid #a7f3d0; border-radius: 16px; padding: 1.5rem; height: 100%; background: #fff; transition: transform 0.2s, box-shadow 0.2s; }
.cp-ortho-package:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(5,150,105,0.12); }
.cp-ortho-package.featured { border-color: var(--ortho-accent); background: linear-gradient(180deg, #ecfdf5 0%, #fff 40%); position: relative; }
.cp-ortho-package-badge { position: absolute; top: -10px; right: 16px; background: var(--ortho-accent); color: #fff; font-size: 0.6875rem; font-weight: 700; padding: 0.25rem 0.65rem; border-radius: 999px; }
.cp-ortho-journey { display: flex; flex-wrap: wrap; gap: 1rem; counter-reset: ortho-step; }
.cp-ortho-journey-step { flex: 1 1 200px; position: relative; padding: 1.25rem 1.25rem 1.25rem 3.25rem; background: #fff; border-radius: 14px; border: 1px solid rgba(15,23,42,0.08); box-shadow: 0 8px 24px rgba(15,23,42,0.05); }
.cp-ortho-journey-step::before { counter-increment: ortho-step; content: counter(ortho-step); position: absolute; left: 1rem; top: 1.15rem; width: 28px; height: 28px; border-radius: 50%; background: var(--ortho-accent); color: #fff; font-weight: 800; font-size: 0.875rem; display: flex; align-items: center; justify-content: center; }
.cp-ortho-stats { background: var(--ortho-dark); color: #fff; padding: 2rem 0; }
.cp-ortho-stat-num { font-size: 2rem; font-weight: 800; line-height: 1; }
.cp-ortho-stat-label { font-size: 0.8125rem; opacity: 0.85; margin-top: 0.35rem; }
.cp-ortho-banner { background: linear-gradient(90deg, #d1fae5, #ecfdf5); border-radius: 16px; padding: 1.5rem; border: 1px solid #a7f3d0; }
@media (max-width: 575.98px) { .cp-ortho-joint-stats { grid-template-columns: 1fr; } }
