/* ============================================================
   Ermisway — Pricing Page  (BEM: .pn-pricing)
   Loaded only when [projectname_pricing_page] shortcode is present.
   ============================================================ */

/* ──────────────── Custom Properties ──────────────── */
.pn-pricing {
	--pn-teal:          #009689;
	--pn-teal-dark:     #00786f;
	--pn-teal-deeper:   #0d9488;
	--pn-teal-bg:       #f0fdfa;
	--pn-teal-border:   #96f7e4;
	--pn-blue:          #1447e6;
	--pn-badge-bg:      #ffb900;
	--pn-badge-text:    #7b3306;
	--pn-text-dark:     #101828;
	--pn-text-mid:      #364153;
	--pn-text-muted:    #6a7282;
	--pn-text-faint:    #99a1af;
	--pn-border:        #e5e7eb;
	--pn-row-border:    #f3f4f6;
	--pn-row-bg:        #f9fafb;
	--pn-page-bg:       #f8fafc;
	--pn-white:         #ffffff;
	--pn-shadow-card:   0 1px 3px rgba(0,0,0,.10), 0 1px 2px rgba(0,0,0,.10);
	--pn-shadow-pro:    0 25px 50px rgba(0,187,167,.30);
	--pn-radius-card:   16px;
	--pn-radius-btn:    14px;
	--pn-radius-sm:     10px;
	--pn-gradient-pro:  linear-gradient(160deg, #009689 0%, #1447e6 100%);
	--pn-gradient-cta:  linear-gradient(156deg, #009689 0%, #1447e6 100%);
	--pn-font:          'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	font-family: var(--pn-font);
	color:        var(--pn-text-dark);
	background:   var(--pn-white);
	line-height:  1.5;
	overflow-x:   hidden;
}

/* ──────────────── Utility / Reset ──────────────── */
.pn-pricing *,
.pn-pricing *::before,
.pn-pricing *::after {
	box-sizing: border-box;
}

.pn-pricing ul {
	list-style: none;
	margin:     0;
	padding:    0;
}

.pn-pricing a {
	text-decoration: none;
}

/* ──────────────── Layout containers ──────────────── */
.pn-pricing__container {
	width:   100%;
	max-width: 1152px;
	margin:  0 auto;
	padding: 0 24px;
}

.pn-pricing__container--narrow {
	max-width: 768px;
}

/* ──────────────── Gradient text ──────────────── */
.pn-pricing__gradient-text {
	background: linear-gradient(90deg, var(--pn-teal) 0%, var(--pn-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* ======================================================
   HERO
   ====================================================== */
.pn-pricing__hero {
	position:   relative;
	background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
	padding:    80px 0 0;
	text-align: center;
	overflow:   hidden;
}

.pn-pricing__hero-glow {
	position:      absolute;
	border-radius: 50%;
	filter:        blur(64px);
	pointer-events: none;
}

.pn-pricing__hero-glow--center {
	width:      700px;
	height:     500px;
	top:        -160px;
	left:       50%;
	transform:  translateX(-50%);
	background: rgba(0, 213, 190, 0.10);
}

.pn-pricing__hero-glow--right {
	width:      256px;
	height:     256px;
	top:        -80px;
	right:      -80px;
	background: rgba(81, 162, 255, 0.10);
}

/* Badge */
.pn-pricing__badge {
	display:        inline-flex;
	align-items:    center;
	gap:            8px;
	font-size:      12px;
	color:          var(--pn-teal-dark);
	background:     var(--pn-teal-bg);
	border:         1px solid var(--pn-teal-border);
	border-radius:  999px;
	padding:        6px 16px;
	margin-bottom:  24px;
}

.pn-pricing__badge-dot {
	display:       inline-block;
	width:         8px;
	height:        8px;
	border-radius: 50%;
	background:    #00bba7;
	flex-shrink:   0;
}

/* Title */
.pn-pricing__hero-title {
	font-size:      56px;
	font-weight:    700;
	line-height:    1.15;
	letter-spacing: -1px;
	color:          var(--pn-text-dark);
	margin:         0 0 20px;
}

.pn-pricing__hero-sub {
	font-size:    18px;
	color:        var(--pn-text-muted);
	max-width:    512px;
	margin:       0 auto 32px;
	line-height:  1.6;
}

/* Toggle row */
.pn-pricing__toggle-row {
	display:        inline-flex;
	align-items:    center;
	gap:            12px;
	margin-bottom:  12px;
}

.pn-pricing__toggle-label {
	font-size:  14px;
	color:      var(--pn-text-faint);
	cursor:     pointer;
	display:    flex;
	align-items: center;
	gap:        8px;
}

.pn-pricing__toggle-label--active {
	color: var(--pn-text-dark);
}

.pn-pricing__save-pill {
	font-size:     12px;
	color:         var(--pn-teal-dark);
	background:    var(--pn-teal-bg);
	border:        1px solid var(--pn-teal-border);
	border-radius: 999px;
	padding:       3px 10px;
}

/* Toggle button */
.pn-pricing__toggle-btn {
	position:      relative;
	display:       inline-flex;
	align-items:   center;
	width:         56px;
	height:        28px;
	border-radius: 999px;
	background:    var(--pn-teal-deeper);
	border:        none;
	cursor:        pointer;
	padding:       4px;
	transition:    background 0.2s;
	flex-shrink:   0;
}

.pn-pricing__toggle-knob {
	display:       block;
	width:         20px;
	height:        20px;
	border-radius: 50%;
	background:    var(--pn-white);
	box-shadow:    0 2px 4px rgba(0,0,0,.15);
	transition:    transform 0.2s;
}

.pn-pricing__toggle-btn--yearly .pn-pricing__toggle-knob {
	transform: translateX(28px);
}

/* Net note */
.pn-pricing__net-note {
	font-size:    12px;
	color:        var(--pn-text-faint);
	margin-bottom: 0;
	padding-bottom: 48px;
}

/* ======================================================
   PRICING CARDS SECTION
   ====================================================== */
.pn-pricing__cards-section {
	padding: 0 0 32px;
}

.pn-pricing__cards {
	display:               grid;
	grid-template-columns: repeat(3, 1fr);
	gap:                   32px;
	align-items:           start;
	position:              relative;
}

/* ── Base card ── */
.pn-pricing__card {
	position:      relative;
	background:    var(--pn-white);
	border:        1px solid var(--pn-border);
	border-radius: var(--pn-radius-card);
	padding:       32px;
	box-shadow:    var(--pn-shadow-card);
}

/* ── Pro card ── */
.pn-pricing__card--pro {
	background:    var(--pn-gradient-pro);
	border-color:  transparent;
	box-shadow:    var(--pn-shadow-pro);
	padding-top:   44px;
	margin-top:    -24px;
	padding-bottom: 36px;
}

/* Most Popular badge */
.pn-pricing__popular-badge {
	position:      absolute;
	top:           -16px;
	left:          50%;
	transform:     translateX(-50%);
	display:       inline-flex;
	align-items:   center;
	gap:           6px;
	background:    var(--pn-badge-bg);
	color:         var(--pn-badge-text);
	font-size:     12px;
	font-weight:   400;
	border-radius: 999px;
	padding:       5px 16px;
	white-space:   nowrap;
	box-shadow:    0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.1);
}

/* Card icon */
.pn-pricing__card-icon-wrap {
	margin-bottom: 16px;
}

.pn-pricing__card-icon {
	display:       inline-flex;
	align-items:   center;
	justify-content: center;
	width:         40px;
	height:        40px;
	border-radius: 14px;
	background:    var(--pn-teal-bg);
	flex-shrink:   0;
}

.pn-pricing__card-icon--pro {
	background: rgba(255,255,255,.20);
}

/* Plan name */
.pn-pricing__plan-name {
	font-size:   18px;
	font-weight: 600;
	color:       var(--pn-text-dark);
	margin:      0 0 4px;
}

.pn-pricing__plan-name--pro {
	color: var(--pn-white);
}

/* Plan tagline */
.pn-pricing__plan-tagline {
	font-size:    14px;
	color:        var(--pn-text-muted);
	margin:       0 0 24px;
}

.pn-pricing__plan-tagline--pro {
	color: #cbfbf1;
}

/* Price */
.pn-pricing__price-wrap {
	margin-bottom: 24px;
}

.pn-pricing__price {
	display:     flex;
	align-items: baseline;
	gap:         4px;
}

.pn-pricing__price-amount {
	font-size:      40px;
	font-weight:    400;
	color:          var(--pn-text-dark);
	letter-spacing: -1px;
	line-height:    1;
}

.pn-pricing__price-amount--pro {
	font-size:      48px;
	color:          var(--pn-white);
	letter-spacing: -1.2px;
}

.pn-pricing__price-period {
	font-size: 14px;
	color:     var(--pn-text-muted);
	align-self: flex-end;
	padding-bottom: 6px;
}

.pn-pricing__price-period--pro {
	color: #cbfbf1;
}

.pn-pricing__price-sub {
	font-size:   14px;
	color:       var(--pn-text-muted);
	margin:      4px 0 0;
	min-height:  20px;
}

.pn-pricing__price-sub--pro {
	color: #cbfbf1;
}

/* ── Buttons ── */
.pn-pricing__btn {
	display:        block;
	width:          100%;
	padding:        12px 20px;
	border-radius:  var(--pn-radius-btn);
	font-size:      14px;
	font-weight:    500;
	text-align:     center;
	cursor:         pointer;
	border:         1px solid transparent;
	transition:     opacity 0.15s, box-shadow 0.15s, transform 0.1s;
	line-height:    1.4;
}

.pn-pricing__btn:hover {
	opacity: 0.92;
	transform: translateY(-1px);
}

.pn-pricing__btn--outline {
	background: var(--pn-white);
	border-color: var(--pn-border);
	color:       var(--pn-text-mid);
}

.pn-pricing__btn--outline:hover {
	border-color: var(--pn-teal);
	color:        var(--pn-teal);
}

.pn-pricing__btn--pro {
	background:  var(--pn-white);
	color:       var(--pn-teal-dark);
	box-shadow:  0 4px 6px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.10);
}

.pn-pricing__btn--dark {
	background: var(--pn-text-dark);
	color:      var(--pn-white);
}

.pn-pricing__btn--dark:hover {
	opacity: .88;
}

/* Divider */
.pn-pricing__divider {
	border: none;
	border-top: 1px solid var(--pn-row-border);
	margin: 24px 0;
}

.pn-pricing__divider--pro {
	border-color: rgba(255,255,255,.20);
}

/* Feature list */
.pn-pricing__features {
	display:        flex;
	flex-direction: column;
	gap:            12px;
}

.pn-pricing__feature {
	display:     flex;
	align-items: flex-start;
	gap:         10px;
	font-size:   14px;
	color:       #4a5565;
}

.pn-pricing__feature--pro {
	color: #f0fdfa;
}

.pn-pricing__check {
	display:       inline-flex;
	align-items:   center;
	justify-content: center;
	width:         20px;
	height:        20px;
	border-radius: 50%;
	background:    var(--pn-teal-bg);
	flex-shrink:   0;
	margin-top:    1px;
}

.pn-pricing__check--pro {
	background: rgba(255,255,255,.20);
}

/* Note below cards */
.pn-pricing__cards-note {
	font-size:   12px;
	color:       var(--pn-text-faint);
	text-align:  center;
	margin-top:  24px;
}

/* ======================================================
   COMPARE TABLE
   ====================================================== */
.pn-pricing__compare {
	background:  var(--pn-page-bg);
	padding:     80px 0;
}

.pn-pricing__section-title {
	font-size:   30px;
	font-weight: 700;
	text-align:  center;
	color:       var(--pn-text-dark);
	margin:      0 0 12px;
}

.pn-pricing__section-sub {
	font-size:    16px;
	color:        var(--pn-text-muted);
	text-align:   center;
	margin:       0 0 40px;
}

.pn-pricing__table-wrap {
	background:    var(--pn-white);
	border:        1px solid var(--pn-border);
	border-radius: var(--pn-radius-card);
	overflow:      hidden;
	box-shadow:    var(--pn-shadow-card);
}

.pn-pricing__table {
	width:           100%;
	border-collapse: collapse;
	font-size:       14px;
}

/* Table header */
.pn-pricing__th {
	padding:    20px 16px;
	text-align: center;
	border-bottom: 1px solid var(--pn-row-border);
	vertical-align: middle;
}

.pn-pricing__th--feature {
	text-align:  left;
	padding-left: 24px;
	width:        40%;
}

.pn-pricing__th--pro-col {
	background: rgba(0,150,137,.05);
}

.pn-pricing__th-name {
	display:     block;
	font-size:   14px;
	font-weight: 700;
	color:       var(--pn-text-dark);
}

.pn-pricing__th-name--pro {
	color: var(--pn-teal);
}

.pn-pricing__th-price {
	display:     block;
	font-size:   12px;
	font-weight: 700;
	color:       var(--pn-text-faint);
	margin-top:  4px;
}

.pn-pricing__th-price--pro {
	color: var(--pn-teal);
}

/* Table group label */
.pn-pricing__table-group td {
	background:     var(--pn-row-bg);
	border-top:     1px solid var(--pn-row-border);
	font-size:      11px;
	font-weight:    400;
	color:          var(--pn-text-faint);
	text-transform: uppercase;
	letter-spacing: .6px;
	padding:        12px 24px;
}

/* Table data cells */
.pn-pricing__td {
	padding:    0;
	height:     53px;
	border-top: 1px solid var(--pn-row-bg);
	text-align: center;
	vertical-align: middle;
	color:      var(--pn-text-mid);
}

.pn-pricing__td--label {
	text-align:  left;
	padding:     0 16px 0 24px;
	font-size:   14px;
	width:       40%;
}

.pn-pricing__td--val {
	width: 20%;
}

.pn-pricing__td--pro-col {
	background: rgba(0,150,137,.05);
}

.pn-pricing__tbl-check {
	display:        inline-flex;
	align-items:    center;
	justify-content: center;
	color:          var(--pn-teal);
}

.pn-pricing__tbl-x {
	display:        inline-flex;
	align-items:    center;
	justify-content: center;
	color:          #d1d5dc;
}

/* ======================================================
   TRUST STATS
   ====================================================== */
.pn-pricing__trust {
	background:  var(--pn-white);
	border-top:  1px solid var(--pn-row-border);
	border-bottom: 1px solid var(--pn-row-border);
	padding:     48px 0;
}

.pn-pricing__trust-grid {
	display:               grid;
	grid-template-columns: repeat(4, 1fr);
	gap:                   32px;
}

.pn-pricing__trust-item {
	display:        flex;
	flex-direction: column;
	align-items:    center;
	gap:            12px;
	text-align:     center;
}

.pn-pricing__trust-icon-wrap {
	display:        inline-flex;
	align-items:    center;
	justify-content: center;
	width:          48px;
	height:         48px;
	border-radius:  14px;
	background:     var(--pn-teal-bg);
	flex-shrink:    0;
}

.pn-pricing__trust-label {
	display:     block;
	font-size:   16px;
	font-weight: 600;
	color:       var(--pn-text-dark);
}

.pn-pricing__trust-sub {
	display:   block;
	font-size: 14px;
	color:     var(--pn-text-muted);
}

/* ======================================================
   FAQ
   ====================================================== */
.pn-pricing__faq {
	padding: 80px 0;
}

.pn-pricing__faq .pn-pricing__section-sub {
	margin-bottom: 40px;
}

.pn-pricing__link {
	color:           var(--pn-teal);
	text-decoration: underline;
}

.pn-pricing__faq-list {
	display:        flex;
	flex-direction: column;
	gap:            12px;
}

.pn-pricing__faq-item {
	background:    var(--pn-white);
	border:        1px solid var(--pn-border);
	border-radius: 14px;
	overflow:      hidden;
}

.pn-pricing__faq-btn {
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	width:           100%;
	padding:         20px 24px;
	background:      none;
	border:          none;
	cursor:          pointer;
	font-size:       14px;
	font-weight:     500;
	color:           var(--pn-text-dark);
	text-align:      left;
	gap:             16px;
	font-family:     inherit;
}

.pn-pricing__faq-btn:focus-visible {
	outline: 2px solid var(--pn-teal);
	outline-offset: -2px;
}

.pn-pricing__faq-icon {
	flex-shrink: 0;
	color:       var(--pn-text-faint);
	display:     flex;
	align-items: center;
}

.pn-pricing__faq-chevron {
	transition: transform .2s;
}

.pn-pricing__faq-btn[aria-expanded="true"] .pn-pricing__faq-chevron {
	transform: rotate(180deg);
}

.pn-pricing__faq-body {
	padding:    0 24px 20px;
	font-size:  14px;
	color:      var(--pn-text-muted);
	line-height: 1.7;
}

.pn-pricing__faq-body p {
	margin: 0;
}

/* ======================================================
   CTA BAND
   ====================================================== */
.pn-pricing__cta {
	background:    var(--pn-gradient-cta);
	border-radius: 24px;
	margin:        0 24px 80px;
	padding:       56px 40px;
	text-align:    center;
	box-shadow:    0 20px 25px -5px rgba(0,187,167,.20), 0 8px 10px -6px rgba(0,187,167,.20);
	overflow:      hidden;
	position:      relative;
}

.pn-pricing__cta-eyebrow {
	font-size:      12px;
	font-weight:    400;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color:          #96f7e4;
	margin:         0 0 12px;
}

.pn-pricing__cta-title {
	font-size:   32px;
	font-weight: 700;
	color:       var(--pn-white);
	margin:      0 0 16px;
}

.pn-pricing__cta-sub {
	font-size:  16px;
	color:      #cbfbf1;
	margin:     0 auto 32px;
	max-width:  400px;
	line-height: 1.6;
}

.pn-pricing__cta-btns {
	display:        flex;
	gap:            16px;
	justify-content: center;
	flex-wrap:      wrap;
	margin-bottom:  24px;
}

.pn-pricing__btn--cta-primary {
	width:       auto;
	display:     inline-block;
	background:  var(--pn-white);
	color:       var(--pn-teal-dark);
	box-shadow:  0 4px 6px rgba(0,0,0,.10), 0 2px 4px rgba(0,0,0,.10);
	padding:     12px 28px;
}

.pn-pricing__btn--cta-ghost {
	width:       auto;
	display:     inline-block;
	border:      1px solid rgba(255,255,255,.30);
	color:       var(--pn-white);
	padding:     12px 28px;
}

.pn-pricing__btn--cta-ghost:hover {
	background: rgba(255,255,255,.10);
	opacity:    1;
}

.pn-pricing__cta-note {
	font-size: 12px;
	color:     #96f7e4;
	margin:    0;
}

/* ======================================================
   RESPONSIVE — Tablet (≤1024px)
   ====================================================== */
@media (max-width: 1024px) {
	.pn-pricing__cards {
		grid-template-columns: 1fr 1fr;
		gap:                   24px;
	}

	.pn-pricing__card--pro {
		margin-top: 0;
	}

	/* Starter goes full width on its own row, Pro + Premium side-by-side */
	.pn-pricing__card--starter {
		grid-column: 1 / -1;
		max-width:   480px;
		margin:      0 auto;
	}

	.pn-pricing__trust-grid {
		grid-template-columns: repeat(2, 1fr);
		gap:                   24px;
	}

	.pn-pricing__hero-title {
		font-size: 44px;
	}
}

/* ======================================================
   RESPONSIVE — Mobile (≤768px)
   ====================================================== */
@media (max-width: 768px) {
	.pn-pricing__hero-title {
		font-size:   36px;
		line-height: 1.2;
	}

	.pn-pricing__hero-sub {
		font-size: 16px;
	}

	.pn-pricing__cards {
		grid-template-columns: 1fr;
	}

	/* Pro card goes first on mobile per Figma note */
	.pn-pricing__card--pro {
		order: -1;
		margin-top: 16px;
	}

	.pn-pricing__card--starter {
		grid-column: auto;
		max-width:   none;
		margin:      0;
	}

	.pn-pricing__trust-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.pn-pricing__cta {
		margin:  0 16px 48px;
		padding: 40px 24px;
	}

	.pn-pricing__cta-title {
		font-size: 26px;
	}

	.pn-pricing__cta-btns {
		flex-direction: column;
		align-items:    stretch;
	}

	.pn-pricing__btn--cta-primary,
	.pn-pricing__btn--cta-ghost {
		width:      100%;
		display:    block;
		text-align: center;
	}

	/* Compare table: enable horizontal scroll */
	.pn-pricing__table-wrap {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	.pn-pricing__table {
		min-width: 560px;
	}

	.pn-pricing__section-title {
		font-size: 24px;
	}

	.pn-pricing__compare,
	.pn-pricing__faq {
		padding: 56px 0;
	}
}

/* ======================================================
   RESPONSIVE — Small Mobile (≤480px)
   ====================================================== */
@media (max-width: 480px) {
	.pn-pricing__hero {
		padding-top: 56px;
	}

	.pn-pricing__hero-title {
		font-size: 30px;
	}

	.pn-pricing__trust-grid {
		grid-template-columns: 1fr;
	}

	.pn-pricing__toggle-row {
		flex-wrap: wrap;
		justify-content: center;
	}
}
