.pro-page {
	--pro-green: #20a53a;
	--pro-green-dark: #17872e;
	--pro-green-soft: #e7f6ea;
	--pro-green-pale: #f4fbf6;
	--pro-ink: #142016;
	--pro-muted: #6f7973;
	--pro-border: #dce8df;
	--pro-card: #ffffff;
	--pricing-primary: #20a53a;
	--pricing-ink: #0f172a;
	--pricing-text-light: #666;
	--bg-light: #f8fafc;
	--card-radius: 24px;
	--small-radius: 12px;
	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "PingFang SC", "Microsoft YaHei", sans-serif;
	background: #fff;
	color: var(--pro-ink);
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

.pro-page *,
.pro-page *::before,
.pro-page *::after {
	box-sizing: border-box;
}

.pro-page a {
	text-decoration: none;
}

.pro-container {
	position: relative;
	z-index: 1;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}

.pro-hero {
	position: relative;
	overflow: hidden;
	padding: 108px 20px 118px;
	background:
		linear-gradient(180deg, #eff9f1 0%, rgba(239, 249, 241, 0) 76%),
		#f7fcf8;
}

.pro-hero-inner {
	display: grid;
	grid-template-columns: minmax(0, 0.9fr) minmax(420px, 1fr);
	align-items: center;
	gap: 78px;
}

.pro-hero-copy {
	max-width: 540px;
}

.pro-hero-title {
	max-width: 540px;
	margin: 0;
	font-size: clamp(46px, 4.6vw, 66px);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: 1.5px;
	white-space: nowrap;
	color: #162318;
}

.pro-hero-title span {
	display: inline-block;
	padding-bottom: 0.08em;
	line-height: 1.18;
	color: var(--pro-green);
}

.pro-hero-subtitle {
	margin: 24px 0 0;
	max-width: 520px;
	font-size: 18px;
	font-weight: 400;
	line-height: 1.6;
	color: #666666;
}

.pro-hero-subtitle strong {
	display: block;
	margin-bottom: 7px;
	color: var(--dark-navy, #0f172a);
	font-size: inherit;
	font-weight: 600;
	line-height: 1.6;
}

.pro-actions {
	display: flex;
	align-items: stretch;
	gap: 22px;
	margin-top: 30px;
}

.pro-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 60px;
	padding: 0 24px;
	border: 1px solid var(--pro-green);
	border-radius: 8px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.2;
	white-space: nowrap;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.pro-btn:hover,
.pro-btn:focus {
	text-decoration: none;
	transform: translateY(-2px);
}

.pro-btn-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 auto;
}

.pro-btn-icon::before {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	background: currentColor;
	mask: var(--pro-btn-icon) center / contain no-repeat;
	-webkit-mask: var(--pro-btn-icon) center / contain no-repeat;
}

.pro-btn-icon-arrow {
	--pro-btn-icon: url("/static/new/images/feature/nginx/right.svg");
	width: 20px;
	height: 20px;
	margin-left: 12px;
}

.pro-btn-icon-bolt {
	--pro-btn-icon: url("/static/new/images/feature/nginx/lightning.svg");
	width: 20px;
	height: 20px;
	margin-left: 12px;
}

.pro-btn-primary {
	background: var(--pro-green);
	color: #fff;
	box-shadow: 0 14px 28px rgba(32, 165, 58, 0.24);
}

.pro-btn-primary:hover,
.pro-btn-primary:focus {
	background: var(--pro-green-dark);
	color: #fff;
	box-shadow: 0 18px 34px rgba(32, 165, 58, 0.3);
}

.pro-btn-secondary {
	background: #fff;
	color: var(--pro-green);
	box-shadow: 0 12px 24px rgba(20, 32, 22, 0.04);
}

.pro-btn-secondary:hover,
.pro-btn-secondary:focus {
	background: #f6fff8;
	color: var(--pro-green-dark);
	box-shadow: 0 14px 28px rgba(32, 165, 58, 0.12);
}

.pro-actions .install-pro-btn {
	min-width: 310px;
}

.pro-actions .buy-now-btn {
	min-width: 156px;
}

.pro-hero-copy .trust-badge {
	margin-top: 28px;
	padding-top: 20px;
	border-top: 1px solid var(--pro-border);
}

.pro-hero-copy .trust-stats {
	display: flex;
	align-items: center;
	gap: 18px;
}

.pro-hero-copy .trust-stat {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.pro-hero-copy .trust-stat-row {
	display: flex;
	align-items: center;
	gap: 6px;
}

.pro-hero-copy .trust-stat-value {
	font-size: 20px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--pro-ink);
}

.pro-hero-copy .trust-stat-label {
	font-size: 12px;
	color: var(--pro-muted);
	white-space: nowrap;
}

.pro-hero-copy .trust-stat-divider {
	flex-shrink: 0;
	width: 1px;
	height: 32px;
	background: var(--pro-border);
}

.pro-visual {
	position: relative;
	min-height: 500px;
	border-radius: 18px;
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(241, 250, 243, 0.72)),
		#eaf6ee;
	box-shadow: 0 28px 70px rgba(20, 32, 22, 0.08);
}

.pro-hero-visual {
	padding: 28px;
}

.pro-hero-visual::before,
.pro-hero-visual::after {
	content: "";
	position: absolute;
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 16px 34px rgba(20, 32, 22, 0.08);
}

.pro-hero-visual::before {
	top: 28px;
	left: 28px;
	right: 34px;
	height: 92px;
}

.pro-hero-visual::after {
	right: 34px;
	bottom: 34px;
	width: 45%;
	height: 210px;
}

.pro-hero-grid {
	position: absolute;
	left: 28px;
	right: 34px;
	top: 148px;
	bottom: 34px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	grid-auto-rows: minmax(120px, 1fr);
	gap: 18px;
}

.pro-hero-tile {
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 14px 30px rgba(20, 32, 22, 0.07);
}

.pro-section {
	padding: 96px 20px;
	background: #fff;
}

.pro-section-soft {
	background: #f6faf8;
}

.pro-feature-list {
	display: flex;
	flex-direction: column;
	gap: 64px;
	margin-top: 72px;
}

.pro-feature {
	display: grid;
	grid-template-columns: minmax(0, 0.82fr) minmax(420px, 1fr);
	align-items: center;
	gap: 76px;
	min-height: 430px;
	padding: 48px 66px;
	border: 1px solid #DCDFE6;
	border-radius: 18px;
	background: #fff;
}

.pro-feature-reverse {
	border-color: #f8fafc;
	background: #f8fafc;
}

.pro-feature-reverse .pro-feature-copy {
	order: 2;
}

.pro-feature-reverse .pro-feature-media {
	order: 1;
}

.pro-chip {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	min-height: 32px;
	padding: 0 16px;
	border-radius: 999px;
	border: 1px solid #E4F4E7;
	background-color: #E4F4E733;
	color: var(--pro-green);
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
}

.pro-chip::before {
	content: "";
	display: block;
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	background: currentColor;
	mask: url("/static/images/icons/monitor.svg") center / contain no-repeat;
	-webkit-mask: url("/static/images/icons/monitor.svg") center / contain no-repeat;
}

.pro-chip-support {
	border-color: #3465EB;
	background-color: #F0F9FF;
	color: #3465EB;
}

.pro-chip-support::before {
	mask-image: url("/static/images/icons/support.svg");
	-webkit-mask-image: url("/static/images/icons/support.svg");
}

.pro-chip-wordpress {
	border-color: #8B5CF6;
	background-color: #F6F2FE;
	color: #8B5CF6;
}

.pro-chip-wordpress::before {
	mask-image: url("/static/images/icons/wordpress.svg");
	-webkit-mask-image: url("/static/images/icons/wordpress.svg");
}

.pro-chip-security {
	border-color: #FFAE45;
	background-color: #FEFCE8;
	color: #FFAE45;
}

.pro-chip-security::before {
	mask-image: url("/static/images/icons/security.svg");
	-webkit-mask-image: url("/static/images/icons/security.svg");
}

.pro-feature h3 {
	margin: 18px 0 0;
	font-size: 28px;
	font-weight: 700;
	line-height: 1.24;
	color: #162318;
}

.pro-feature p {
	margin: 16px 0 0;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.62;
	color: #748079;
}

.pro-feature-media {
	min-height: 290px;
	border-radius: 16px;
	background: transparent;
	box-shadow: none;
}

.pro-page .browser-window {
	width: 100%;
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: var(--card-radius);
	box-shadow: var(--shadow-md);
	overflow: hidden;
	transition: box-shadow 0.25s ease;
}

.pro-page .browser-window:hover {
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.08);
}

.pro-page .browser-window svg {
	display: block;
	fill: none;
}

.pro-page .bw-titlebar {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 20px;
	background: #f1f5f9;
	border-bottom: 1px solid var(--border-color);
}

.pro-page .bw-dots {
	display: flex;
	flex-shrink: 0;
	gap: 7px;
}

.pro-page .bw-dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	transition: opacity 0.2s;
}

.pro-page .bw-dot:hover {
	opacity: 0.7;
}

.pro-page .bw-dot-red {
	background: #fa625c;
}

.pro-page .bw-dot-yellow {
	background: #fbbf24;
}

.pro-page .bw-dot-green {
	background: #22c55e;
}

.pro-page .bw-title {
	flex: 1;
	color: var(--text-secondary);
	font-size: 13px;
	font-weight: 600;
}

.pro-page .bw-content {
	padding: 20px;
}

.pro-page .wp-manager-content {
	position: relative;
	padding: 24px 28px 20px;
}

.pro-page .wp-action {
	--wp-accent: var(--primary-green);
	--wp-accent-soft: rgba(32, 165, 58, 0.08);
	--wp-hover: var(--wp-accent);
	--wp-hover-shadow: rgba(32, 165, 58, 0.28);
	--wp-group-offset: 60px;
	--wp-offset: 0px;
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	gap: 12px;
	width: 310px;
	min-height: 66px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 16px;
	padding: 13px 20px;
	border: 2px solid var(--wp-accent);
	border-radius: 999px;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
	color: var(--dark-navy);
	cursor: default;
	transform: translateX(calc(var(--wp-group-offset) + var(--wp-offset)));
	transition: transform 0.28s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.28s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.28s ease, border-color 0.28s ease, color 0.28s ease;
}

.pro-page .wp-action:last-child {
	margin-bottom: 0;
}

.pro-page .wp-action:hover {
	transform: translateX(calc(var(--wp-group-offset) + var(--wp-offset))) translateY(-2px) scale(1.02);
	border-color: var(--wp-hover);
	background: var(--wp-hover);
	box-shadow: 0 8px 28px var(--wp-hover-shadow);
	color: #fff;
}

.pro-page .wp-action-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 36px;
	width: 36px;
	height: 36px;
	border-radius: 12px;
	background: var(--wp-accent-soft);
	color: var(--wp-accent);
	transition: background-color 0.28s ease, color 0.28s ease;
}

.pro-page .wp-action:hover .wp-action-icon,
.pro-page .wp-action-active .wp-action-icon {
	background: rgba(255, 255, 255, 0.22);
	color: #fff;
}

.pro-page .wp-action-icon svg {
	width: 18px;
	height: 18px;
}

.pro-page .wp-action-text {
	flex: 1;
	min-width: 0;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.25;
	white-space: nowrap;
	transition: color 0.28s ease;
}

.pro-page .wp-action-arrow {
	flex-shrink: 0;
	width: 16px;
	height: 16px;
	color: var(--wp-accent);
	opacity: 0.55;
	transition: color 0.28s ease;
}

.pro-page .wp-action:hover .wp-action-arrow,
.pro-page .wp-action-active .wp-action-arrow {
	color: #fff;
}

.pro-page .wp-action-active {
	z-index: 4;
	border-color: var(--wp-accent);
	background: var(--wp-accent);
	box-shadow: 0 10px 32px var(--wp-hover-shadow);
	color: #fff;
}

.pro-page .wp-action-active:hover {
	transform: translateX(calc(var(--wp-group-offset) + var(--wp-offset)));
	border-color: var(--wp-accent);
	background: var(--wp-accent);
	box-shadow: 0 10px 32px var(--wp-hover-shadow);
}

.pro-page .wp-action-login {
	--wp-accent: #20a53a;
	--wp-accent-soft: rgba(32, 165, 58, 0.08);
	--wp-hover-shadow: rgba(32, 165, 58, 0.28);
	--wp-offset: -40px;
	z-index: 3;
}

.pro-page .wp-action-deploy {
	--wp-accent: #3B82F6;
	--wp-accent-soft: rgba(59, 130, 246, 0.08);
	--wp-hover: #3B82F6;
	--wp-hover-shadow: rgba(59, 130, 246, 0.28);
	--wp-group-offset: 60px;
}

.pro-page .wp-action-file {
	--wp-accent: #f59e0b;
	--wp-accent-soft: rgba(245, 158, 11, 0.08);
	--wp-hover-shadow: rgba(245, 158, 11, 0.28);
	--wp-offset: -80px;
	z-index: 2;
}

.pro-page .wp-action-scan {
	--wp-accent: #8b5cf6;
	--wp-accent-soft: rgba(139, 92, 246, 0.08);
	--wp-hover-shadow: rgba(139, 92, 246, 0.28);
	--wp-offset: -120px;
}

.pro-page .wp-toggle {
	position: relative;
	flex-shrink: 0;
	width: 32px;
	height: 18px;
	border-radius: 10px;
	background: var(--wp-accent);
	transition: background-color 0.28s ease;
}

.pro-page .wp-action:hover .wp-toggle {
	background: rgba(255, 255, 255, 0.35);
}

.pro-page .wp-toggle-dot {
	position: absolute;
	top: 2px;
	right: 2px;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}

.pro-page .bw-section-label {
	margin-bottom: 12px;
	color: var(--text-muted);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.pro-page .bw-status-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-bottom: 4px;
}

.pro-page .bw-status-item {
	display: flex;
	align-items: center;
	flex: 1 1 auto;
	gap: 6px;
	min-width: 100px;
	padding: 8px 14px;
	border: 1px solid var(--border-color);
	border-radius: var(--small-radius);
	background: var(--bg-light);
}

.pro-page .bw-status-dot {
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	border-radius: 50%;
}

.pro-page .bw-status-dot.green {
	background: var(--primary-green);
}

.pro-page .bw-status-dot.orange {
	background: #f59e0b;
}

.pro-page .bw-status-dot.red {
	background: #fa625c;
}

.pro-page .bw-status-name {
	flex: 1;
	color: var(--text-secondary);
	font-size: 12px;
	font-weight: 500;
}

.pro-page .bw-status-badge {
	padding: 2px 10px;
	border-radius: 10px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.03em;
}

.pro-page .bw-status-badge.online {
	background: #ecfdf5;
	color: #16a34a;
}

.pro-page .bw-status-value {
	color: var(--dark-navy);
	font-size: 14px;
	font-weight: 700;
}

.pro-page .bw-status-value small {
	color: var(--text-muted);
	font-size: 11px;
	font-weight: 600;
}

.pro-page .bw-status-value.success {
	color: var(--primary-green);
}

.pro-page .bw-divider {
	height: 1px;
	margin: 16px 0;
	background: var(--border-color);
}

.pro-page .bw-metrics-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 12px;
	margin-bottom: 4px;
}

.pro-page .bw-metric {
	padding: 14px 16px;
	border: 1px solid var(--border-color);
	border-radius: var(--small-radius);
	background: var(--bg-light);
	text-align: center;
}

.pro-page .bw-metric-label {
	display: block;
	margin-bottom: 4px;
	color: var(--text-muted);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.pro-page .bw-metric-value {
	display: block;
	color: var(--dark-navy);
	font-size: 18px;
	font-weight: 800;
	line-height: 1.2;
}

.pro-page .bw-metric-value small {
	color: var(--text-muted);
	font-size: 12px;
	font-weight: 600;
}

.pro-page .bw-http-section {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.pro-page .bw-http-header-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 4px;
}

.pro-page .bw-http-label {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--text-secondary);
	font-size: 12px;
	font-weight: 500;
}

.pro-page .bw-http-dot {
	flex-shrink: 0;
	width: 8px;
	height: 8px;
	border-radius: 50%;
}

.pro-page .bw-http-count {
	color: var(--dark-navy);
	font-size: 13px;
	font-weight: 700;
}

.pro-page .bw-http-bar-bg {
	width: 100%;
	height: 6px;
	overflow: hidden;
	border-radius: 3px;
	background: #e8e8e8;
}

.pro-page .bw-http-bar-fill {
	height: 100%;
	border-radius: 3px;
	transition: width 0.6s ease;
}

.pro-page .chat-area {
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding: 4px 0;
}

.pro-page .chat-message {
	display: flex;
	gap: 10px;
	max-width: 88%;
}

.pro-page .chat-message.support {
	align-self: flex-start;
}

.pro-page .chat-message.user {
	align-self: flex-end;
	flex-direction: row-reverse;
}

.pro-page .chat-avatar {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 30px;
	height: 30px;
	border-radius: 10px;
	font-size: 12px;
	font-weight: 700;
}

.pro-page .chat-avatar.support {
	background: #f0f9ff;
	color: #2563eb;
}

.pro-page .chat-avatar.user {
	background: #f4faf5;
	color: var(--primary-green);
}

.pro-page .chat-bubble {
	padding: 10px 14px;
	border-radius: 12px;
	color: var(--dark-navy);
	font-size: 12px;
	line-height: 1.6;
}

.pro-page .chat-message.support .chat-bubble {
	border-bottom-left-radius: 4px;
	background: #f1f5f9;
}

.pro-page .chat-message.user .chat-bubble {
	border-bottom-right-radius: 4px;
	background: #ecfdf5;
}

.pro-page .chat-input-bar {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-top: 6px;
	padding: 10px 14px;
	border: 1px solid var(--border-color);
	border-radius: var(--small-radius);
	background: var(--bg-light);
}

.pro-page .chat-input-field {
	flex: 1;
	border: none;
	outline: none;
	background: transparent;
	color: var(--dark-navy);
	font-family: inherit;
	font-size: 12px;
}

.pro-page .chat-input-field::placeholder {
	color: var(--text-muted);
}

.pro-page .chat-send-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 28px;
	height: 28px;
	border: none;
	border-radius: 8px;
	background: var(--primary-green);
	color: #fff;
	cursor: pointer;
}

.pro-page .chat-send-btn svg {
	width: 14px;
	height: 14px;
}

.pro-page .chat-time {
	margin-top: 2px;
	padding: 0 2px;
	color: var(--text-muted);
	font-size: 10px;
}

.pro-page .chat-message.support .chat-time {
	padding-left: 40px;
}

.pro-page .chat-message.user .chat-time {
	padding-right: 0;
	text-align: right;
}

.pro-page .sec-metrics {
	display: flex;
	gap: 12px;
	margin-bottom: 16px;
}

.pro-page .sec-metric {
	flex: 1;
	padding: 14px 12px;
	border: 1px solid var(--border-color);
	border-radius: var(--small-radius);
	background: var(--bg-light);
	text-align: center;
}

.pro-page .sec-metric-value {
	display: block;
	margin-bottom: 2px;
	color: var(--dark-navy);
	font-size: 22px;
	font-weight: 800;
	line-height: 1.2;
}

.pro-page .sec-metric-value.qps {
	color: var(--primary-green);
}

.pro-page .sec-metric-value.danger {
	color: #fa625c;
}

.pro-page .sec-metric-label {
	display: block;
	color: var(--text-muted);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.pro-page .sec-events {
	overflow: hidden;
	border: 1px solid var(--border-color);
	border-radius: var(--small-radius);
}

.pro-page .sec-event-row {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 9px 14px;
	border-bottom: 1px solid var(--border-color);
	font-size: 12px;
}

.pro-page .sec-event-row:last-child {
	border-bottom: none;
}

.pro-page .sec-event-header {
	background: var(--bg-light);
	color: var(--text-muted);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.pro-page .sec-event-ip {
	flex-shrink: 0;
	width: 120px;
	overflow: hidden;
	color: var(--dark-navy);
	font-family: "SF Mono", "Fira Code", monospace;
	font-weight: 500;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.pro-page .sec-event-domain {
	flex: 0 0 100px;
	overflow: hidden;
	color: var(--text-secondary);
	white-space: nowrap;
	text-overflow: ellipsis;
}

.pro-page .sec-event-type {
	flex: 0 0 100px;
}

.pro-page .sec-event-url {
	flex: 1;
	min-width: 0;
	overflow: hidden;
	color: var(--text-secondary);
	font-family: "SF Mono", "Fira Code", monospace;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.pro-page .sec-type-badge {
	display: inline-block;
	padding: 3px 10px;
	border-radius: 4px;
	font-size: 10px;
	font-weight: 700;
	white-space: nowrap;
}

.pro-page .sec-type-badge.sql {
	background: #fef2f2;
	color: #dc2626;
}

.pro-page .sec-type-badge.xss {
	background: #fff7ed;
	color: #ea580c;
}

.pro-page .sec-type-badge.cc {
	background: #fefce8;
	color: #ca8a04;
}

.pro-page .sec-type-badge.brute {
	background: #f0f9ff;
	color: #2563eb;
}

.pro-pricing-reuse {
	background: #fff;
}

.pro-pricing-bg-white {
	background: #fff !important;
}

.pro-pricing-bg-soft {
	background: var(--pricing-surface-soft) !important;
}

.pro-pricing-reuse .pricing-pro-extensions {
	padding-bottom: 120px;
}

@media (max-width: 768px) {
	.pro-pricing-reuse .pricing-pro-extensions {
		padding-bottom: 72px;
	}
}

.pro-page .pricing-section-header {
	display: flex;
	align-items: center;
	flex-direction: column;
}

.pro-page .pricing-section-header h2 {
	order: 1;
}

.pro-page .pricing-section-header p {
	order: 2;
}

.pro-page .pricing-section-line {
	order: 3;
	margin: 18px auto 0;
}

.pro-pricing-reuse .pro-compare-container {
	max-width: 1120px;
}

.pro-pricing-reuse .pricing-faq-container {
	width: min(940px, calc(100% - 40px));
	max-width: none;
	padding: 0;
}

.pro-pricing-reuse .pricing-pro-icon::before {
	content: "";
	width: 24px;
	height: 24px;
	background: currentColor;
	mask: var(--pricing-pro-icon) center / contain no-repeat;
	-webkit-mask: var(--pricing-pro-icon) center / contain no-repeat;
}

.pro-pricing-reuse .pricing-pro-icon-waf {
	--pricing-pro-icon: url("/static/images/icons/waf.svg");
}

.pro-pricing-reuse .pricing-pro-icon-site-stat {
	--pricing-pro-icon: url("/static/images/icons/site-stat.svg");
}

.pro-pricing-reuse .pricing-pro-icon-wordpress {
	--pricing-pro-icon: url("/static/images/icons/wordpress.svg");
}

.pro-pricing-reuse .pricing-pro-icon-tamper-proof {
	--pricing-pro-icon: url("/static/images/icons/tamper-proof.svg");
}

.pro-pricing-reuse .pricing-pro-icon-app {
	--pricing-pro-icon: url("/static/images/icons/app.svg");
}

.pro-pricing-reuse .pricing-pro-icon-daily {
	--pricing-pro-icon: url("/static/images/icons/daily.svg");
}

.pro-pricing-reuse .pricing-comparison-extra {
	display: none;
}

.pro-pricing-reuse .pricing-comparison-extra.expanded {
	display: table-row-group;
}

.pro-pricing-reuse .pricing-comparison-table td {
	vertical-align: middle;
}

.pro-pricing-reuse .pricing-comparison-table td:not(:first-child) {
	line-height: 1;
}

.pro-pricing-reuse .pricing-ic-check,
.pro-pricing-reuse .pricing-ic-dash {
	display: inline-grid;
	place-items: center;
	vertical-align: middle;
}

.pro-pricing-reuse .pricing-ic-check::before {
	position: relative;
	top: -1px;
	left: 0;
}

.pro-pricing-reuse .pricing-faq-item.open {
	border-color: var(--pricing-primary);
}

.pro-pricing-reuse .pricing-faq-item.open .pricing-faq-answer {
	height: auto;
	padding-bottom: 24px;
	opacity: 1;
}

.pro-pricing-reuse .pricing-faq-answer {
	display: block;
	height: 0;
	max-height: none;
	padding: 0 24px;
	opacity: 0;
	overflow: hidden;
	transition: height 0.34s cubic-bezier(0.22, 1, 0.36, 1), padding-bottom 0.34s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.22s ease;
	will-change: height, padding-bottom, opacity;
}

.pro-pricing-reuse .pricing-faq-question::after {
	transition: transform 0.24s ease;
}

.pro-pricing-reuse .pricing-faq-item.open .pricing-faq-question::after {
	transform: rotate(180deg);
}

@media (prefers-reduced-motion: reduce) {
	.pro-pricing-reuse .pricing-faq-answer,
	.pro-pricing-reuse .pricing-faq-question::after {
		transition: none;
	}
}

.pricing-faq-answer .pro-install-alert {
	margin-bottom: 8px;
	color: #d62525;
	font-size: 14px;
	font-weight: 400;
}

.pro-code-row {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px;
	align-items: center;
	margin-bottom: 16px;
}

.pro-code {
	display: block;
	min-width: 0;
	margin: 0;
	padding: 16px;
	border-radius: 8px;
	background: #1f2923;
	color: #fff;
	font-size: 13px;
	line-height: 1.6;
	white-space: normal;
	word-break: break-all;
	cursor: pointer;
}

.pro-copy {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0;
	background: #fff url("/images/promote/ico-copy.png") center / 26px 30px no-repeat;
	cursor: pointer;
	transition: background-color 0.2s ease, border-color 0.2s ease;
}

.pro-install-steps {
	display: flex;
	flex-direction: column;
	gap: 10px;
	counter-reset: pro-install-step;
	margin: 0;
	padding: 0;
	color: #5f6b64;
	font-size: 14px;
	font-weight: 600;
	line-height: 1.5;
	list-style: none;
}

.pro-install-steps li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	counter-increment: pro-install-step;
}

.pro-install-steps li::before {
	content: counter(pro-install-step) ".";
	flex: 0 0 auto;
	color: inherit;
	font: inherit;
}

@media (max-width: 991px) {
	.pro-hero {
		padding: 84px 18px 86px;
	}

	.pro-hero-inner {
		grid-template-columns: 1fr;
		gap: 48px;
		max-width: 680px;
		margin: 0 auto;
	}

	.pro-hero-copy {
		max-width: none;
		text-align: center;
	}

	.pro-hero-title {
		max-width: 520px;
		margin: 0 auto;
		font-size: 46px;
	}

	.pro-actions {
		justify-content: center;
	}

	.pro-hero-copy .trust-stats {
		justify-content: center;
	}

	.pro-visual {
		min-height: 420px;
	}

	.pro-section {
		padding: 82px 18px;
	}

	.pro-feature-list {
		max-width: 680px;
		margin: 58px auto 0;
		gap: 42px;
	}

	.pro-feature,
	.pro-feature-reverse {
		grid-template-columns: 1fr;
		gap: 28px;
		min-height: 0;
		padding: 36px;
	}

	.pro-feature-reverse .pro-feature-copy,
	.pro-feature-reverse .pro-feature-media {
		order: initial;
	}

	.pro-feature-media {
		min-height: 260px;
	}

	.pro-page .bw-metrics-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.pro-page .bw-status-row {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}

	.pro-page .sec-metrics {
		flex-direction: column;
	}

}

@media (max-width: 640px) {
	.pro-hero {
		padding: 62px 16px 64px;
	}

	.pro-hero-title {
		max-width: 340px;
		font-size: 34px;
		line-height: 1.24;
	}

	.pro-hero-subtitle {
		margin-top: 20px;
		font-size: 14px;
	}

	.pro-actions {
		flex-direction: column;
		gap: 12px;
	}

	.pro-btn {
		width: 100%;
		min-height: 58px;
	}

	.pro-hero-copy .trust-stats {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 16px 18px;
		text-align: left;
	}

	.pro-hero-copy .trust-stat-divider {
		display: none;
	}

	.pro-hero-copy .trust-stat-label {
		white-space: normal;
	}

	.pro-visual {
		min-height: 330px;
		border-radius: 14px;
	}

	.pro-hero-visual::before {
		top: 18px;
		left: 18px;
		right: 18px;
		height: 70px;
	}

	.pro-hero-visual::after {
		right: 18px;
		bottom: 18px;
		width: 42%;
		height: 150px;
	}

	.pro-hero-grid {
		left: 18px;
		right: 18px;
		top: 110px;
		bottom: 18px;
		gap: 12px;
	}

	.pro-section {
		padding: 64px 16px;
	}

	.pro-feature-list {
		gap: 28px;
		margin-top: 44px;
	}

	.pro-feature {
		padding: 24px;
		border-radius: 14px;
	}

	.pro-feature h3 {
		font-size: 24px;
	}

	.pro-feature p {
		font-size: 14px;
	}

	.pro-feature-media {
		min-height: 220px;
		border-radius: 12px;
	}

	.pro-page .bw-metrics-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}

	.pro-page .bw-metric {
		padding: 10px 12px;
	}

	.pro-page .bw-metric-value {
		font-size: 15px;
	}

	.pro-page .bw-status-row {
		grid-template-columns: repeat(2, 1fr);
	}

	.pro-page .bw-content {
		padding: 14px;
	}

	.pro-page .bw-titlebar {
		padding: 10px 14px;
	}

	.pro-code-row {
		grid-template-columns: 1fr;
	}

	.pro-copy {
		justify-self: end;
		width: 44px;
	}
}

.pro-page {
	--primary-green: var(--pro-green, #20a53a);
	--primary-green-hover: var(--pro-green-dark, #1a8a2f);
	--dark-navy: #0f172a;
	--text-secondary: #475569;
	--text-muted: #94a3b8;
	--border-color: rgba(0, 0, 0, 0.06);
	--bg-green-light: #f4faf5;
	--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.04);
	--shadow-md: 0 4px 16px rgba(0, 0, 0, 0.06);
}

.pro-page .pro-visual.pro-hero-visual.hero-dashboard {
	width: 100%;
	min-height: 0;
	padding: 0;
	border-radius: 0;
	background: transparent;
	box-shadow: none;
}

.pro-page .pro-visual.pro-hero-visual.hero-dashboard::before,
.pro-page .pro-visual.pro-hero-visual.hero-dashboard::after {
	display: none;
	content: none;
}

.pro-page .hero-dashboard svg {
	display: block;
	fill: none;
	stroke: currentColor;
}

.pro-page .dash-card {
	background: #fff;
	border: 1px solid var(--border-color);
	border-radius: 18px;
	padding: 18px 20px;
	box-shadow: var(--shadow-sm);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.pro-page .dash-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.pro-page .dash-card .card-header {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 14px;
}

.pro-page .dash-card .card-header svg {
	width: 19px;
	height: 19px;
	color: var(--primary-green);
	flex-shrink: 0;
}

.pro-page .dash-card .card-header h3 {
	margin: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--dark-navy);
	letter-spacing: 0.02em;
}

.pro-page .dash-shield {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 16px;
	padding: 0 20px;
}

.pro-page .dash-shield .sh-info {
	flex: 1;
	min-width: 0;
}

.pro-page .dash-shield .sh-label {
	font-size: 14px;
	font-weight: 500;
	color: var(--text-muted);
	letter-spacing: 0.05em;
}

.pro-page .dash-shield .sh-days {
	font-size: 36px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--dark-navy);
}

.pro-page .dash-shield .sh-days .unit {
	margin-left: 2px;
	font-size: 16px;
	font-weight: 600;
	color: var(--primary-green);
}

.pro-page .dash-top,
.pro-page .dash-middle {
	display: flex;
	gap: 14px;
	margin-bottom: 14px;
}

.pro-page .dash-middle:last-child {
	margin-bottom: 0;
}

.pro-page .dash-middle .dash-card {
	flex: 1;
	min-width: 0;
}

.pro-page .dash-stat {
	display: flex;
	align-items: center;
	flex: 1;
	gap: 16px;
	min-width: 0;
	padding: 18px 22px;
	border: 1px solid var(--border-color);
	border-radius: 18px;
	background: #fff;
	box-shadow: var(--shadow-sm);
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.pro-page .dash-stat:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.pro-page .dash-stat .stat-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	width: 46px;
	height: 46px;
	border-radius: 14px;
	background: var(--bg-green-light);
}

.pro-page .dash-stat .stat-icon svg {
	width: 24px;
	height: 24px;
	color: var(--primary-green);
}

.pro-page .dash-stat .stat-info {
	flex: 1;
	min-width: 0;
}

.pro-page .dash-stat .stat-label {
	font-size: 14px;
	font-weight: 500;
	color: var(--text-muted);
	letter-spacing: 0.04em;
}

.pro-page .dash-stat .stat-value {
	font-size: 28px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--dark-navy);
}

.pro-page .dash-stat .stat-value .unit {
	font-size: 14px;
	font-weight: 600;
	color: var(--text-muted);
}

.pro-page .cpu-gauge {
	position: relative;
	flex-shrink: 0;
	width: 52px;
	height: 52px;
}

.pro-page .cpu-gauge svg {
	width: 52px;
	height: 52px;
	transform: rotate(-90deg);
}

.pro-page .cpu-gauge .bg {
	fill: none;
	stroke: #e8e8e8;
	stroke-width: 5;
}

.pro-page .cpu-gauge .progress {
	fill: none;
	stroke: var(--primary-green);
	stroke-width: 5;
	stroke-linecap: round;
	stroke-dasharray: 138.23;
	stroke-dashoffset: 27.65;
	transition: stroke-dashoffset 1s ease;
}

.pro-page .cpu-gauge .label {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 11px;
	font-weight: 700;
	color: var(--dark-navy);
}

.pro-page .stat-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 7px 0;
	border-bottom: 1px solid var(--border-color);
}

.pro-page .stat-row:last-of-type,
.pro-page .stat-row.is-borderless {
	border-bottom: none;
}

.pro-page .stat-row .label {
	display: flex;
	align-items: center;
	gap: 6px;
	min-width: 0;
	color: var(--text-secondary);
	font-size: 13px;
}

.pro-page .stat-row .label .dot {
	display: inline-block;
	flex-shrink: 0;
	width: 6px;
	height: 6px;
	border-radius: 50%;
}

.pro-page .stat-row .label .dot.green {
	background: var(--primary-green);
}

.pro-page .stat-row .label .dot.orange {
	background: #f59e0b;
}

.pro-page .stat-row .label .dot.red {
	background: #fa625c;
}

.pro-page .stat-row .label .dot.blue {
	background: #3b82f6;
}

.pro-page .stat-row .label .dot.purple {
	background: #9333ea;
}

.pro-page .stat-row .value {
	flex-shrink: 0;
	font-size: 14px;
	font-weight: 700;
	color: var(--dark-navy);
}

.pro-page .top10-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 8px;
	padding: 5px 0;
	font-size: 12px;
}

.pro-page .top10-row .rank {
	width: 18px;
	color: var(--text-muted);
	font-weight: 700;
}

.pro-page .top10-row .host {
	flex: 1;
	min-width: 0;
	color: var(--dark-navy);
	font-family: "SF Mono", "Fira Code", Consolas, monospace;
	font-size: 11px;
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.pro-page .top10-row .conn {
	flex-shrink: 0;
	color: var(--text-secondary);
	font-weight: 600;
}

.pro-page .top10-row .bar-bg {
	width: 60px;
	height: 4px;
	margin-left: 0;
	overflow: hidden;
	border-radius: 2px;
	background: #e8e8e8;
}

.pro-page .top10-row .bar-fill {
	height: 100%;
	border-radius: 2px;
	background: var(--primary-green);
}

.pro-page .tp-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	padding: 6px 0;
	border-bottom: 1px solid var(--border-color);
}

.pro-page .tp-row:last-of-type {
	border-bottom: none;
}

.pro-page .tp-row .tp-label {
	display: flex;
	align-items: center;
	gap: 6px;
	color: var(--text-secondary);
	font-size: 13px;
}

.pro-page .tp-row .tp-badge {
	flex-shrink: 0;
	padding: 2px 10px;
	border-radius: 10px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.03em;
}

.pro-page .tp-row .tp-badge.passed {
	background: #ecfdf5;
	color: #16a34a;
}

.pro-page .tp-row .tp-badge.active {
	background: #f0f9ff;
	color: #2563eb;
}

.pro-page .tp-row .tp-badge.protected {
	background: #f4faf5;
	color: var(--primary-green);
}

.pro-page .tp-row .tp-badge.secure {
	background: #faf5ff;
	color: #9333ea;
}

.pro-page .dash-sync .sync-status-wrap {
	display: flex;
	align-items: center;
	gap: 14px;
	margin-bottom: 10px;
}

.pro-page .dash-sync .sync-dot {
	flex-shrink: 0;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: var(--primary-green);
}

.pro-page .dash-sync .sync-info {
	flex: 1;
	min-width: 0;
}

.pro-page .dash-sync .sync-label {
	color: var(--text-muted);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.pro-page .dash-sync .sync-status-text {
	color: var(--dark-navy);
	font-size: 18px;
	font-weight: 700;
}

.pro-page .dash-sync .sync-meta {
	margin-top: 4px;
	color: var(--text-muted);
	font-size: 12px;
}

.pro-page .dash-sync .sync-progress-track {
	width: 100%;
	height: 4px;
	margin: 0 0 12px;
	overflow: hidden;
	border-radius: 2px;
	background: #e8e8e8;
}

.pro-page .dash-sync .sync-progress-fill {
	width: 62%;
	height: 100%;
	border-radius: 2px;
	background: var(--primary-green);
}

.anim-in {
	--pro-reveal-y: 24px;
	opacity: 0;
	transform: translateY(var(--pro-reveal-y));
	transition: opacity 0.6s ease, transform 0.6s ease;
	transition-delay: 0s;
	will-change: opacity, transform;
}

.anim-in.is-visible {
	--pro-reveal-y: 0px;
	opacity: 1;
}

.anim-in.d1 {
	transition-delay: 0.1s;
}

.anim-in.d2 {
	transition-delay: 0.2s;
}

.anim-in.d3 {
	transition-delay: 0.3s;
}

.anim-in.d4 {
	transition-delay: 0.4s;
}

@media (prefers-reduced-motion: reduce) {
	.anim-in {
		--pro-reveal-y: 0px;
		opacity: 1;
		transition: none;
	}
}

@media (max-width: 991px) {
	.pro-page .pro-visual.pro-hero-visual.hero-dashboard {
		max-width: 680px;
		margin: 0 auto;
	}

}

@media (max-width: 640px) {
	.pro-page .pro-visual.pro-hero-visual.hero-dashboard {
		max-width: none;
	}

	.pro-page .dash-top,
	.pro-page .dash-middle {
		flex-direction: column;
	}

	.pro-page .dash-stat {
		padding: 16px;
	}

	.pro-page .dash-card {
		padding: 16px;
	}

	.pro-page .top10-row .bar-bg {
		width: 48px;
	}
}
