.cp-oph-page { --oph-accent: #0891b2; --oph-dark: #0e7490; --oph-soft: #ecfeff; }
.cp-oph-page .cp-hero { background: linear-gradient(135deg, #0e7490 0%, #0891b2 48%, #22d3ee 100%); position: relative; overflow: hidden; }
.cp-oph-eye-bg { position: absolute; inset: 0; opacity: 0.1; background-image: radial-gradient(circle at 50% 50%, white 8px, transparent 8px); background-size: 48px 48px; pointer-events: none; }
.cp-oph-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-oph-vision-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 0.75rem; margin-bottom: 1rem; }
.cp-oph-vision-stat { text-align: center; padding: 0.65rem 0.5rem; background: var(--oph-soft); border-radius: 12px; border: 1px solid #a5f3fc; }
.cp-oph-vision-stat strong { display: block; font-size: 1.1rem; color: var(--oph-accent); line-height: 1.2; }
.cp-oph-vision-stat span { font-size: 0.6875rem; color: #64748b; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }
.cp-oph-alert { background: linear-gradient(90deg, #ecfeff, #fff); border-left: 4px solid var(--oph-accent); border-radius: 0 12px 12px 0; padding: 1.25rem 1.5rem; }
.cp-oph-alert ul { margin: 0; padding-left: 1.1rem; }
.cp-oph-alert li { margin-bottom: 0.35rem; color: #0e7490; font-weight: 500; }
.cp-oph-service-card { border-top: 3px solid var(--oph-accent); height: 100%; }
.cp-oph-service-card .cp-service-icon { background: var(--oph-accent) !important; }
.cp-oph-pillar { border: 1px solid #a5f3fc; border-radius: 16px; padding: 1.25rem; height: 100%; background: linear-gradient(180deg, #ecfeff 0%, #fff 60%); }
.cp-oph-pillar-icon { width: 44px; height: 44px; border-radius: 12px; background: var(--oph-accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; margin-bottom: 0.75rem; }
.cp-oph-package { border: 2px solid #a5f3fc; border-radius: 16px; padding: 1.5rem; height: 100%; background: #fff; transition: transform 0.2s, box-shadow 0.2s; }
.cp-oph-package:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(8,145,178,0.12); }
.cp-oph-package.featured { border-color: var(--oph-accent); background: linear-gradient(180deg, #ecfeff 0%, #fff 40%); position: relative; }
.cp-oph-package-badge { position: absolute; top: -10px; right: 16px; background: var(--oph-accent); color: #fff; font-size: 0.6875rem; font-weight: 700; padding: 0.25rem 0.65rem; border-radius: 999px; }
.cp-oph-journey { display: flex; flex-wrap: wrap; gap: 1rem; counter-reset: oph-step; }
.cp-oph-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-oph-journey-step::before { counter-increment: oph-step; content: counter(oph-step); position: absolute; left: 1rem; top: 1.15rem; width: 28px; height: 28px; border-radius: 50%; background: var(--oph-accent); color: #fff; font-weight: 800; font-size: 0.875rem; display: flex; align-items: center; justify-content: center; }
.cp-oph-stats { background: var(--oph-dark); color: #fff; padding: 2rem 0; }
.cp-oph-stat-num { font-size: 2rem; font-weight: 800; line-height: 1; }
.cp-oph-stat-label { font-size: 0.8125rem; opacity: 0.85; margin-top: 0.35rem; }
.cp-oph-banner { background: linear-gradient(90deg, #cffafe, #ecfeff); border-radius: 16px; padding: 1.5rem; border: 1px solid #a5f3fc; }
@media (max-width: 575.98px) { .cp-oph-vision-stats { grid-template-columns: 1fr; } }
