/* ==========================================================================
   Photo Earnings Calculator — calculator.css
   Scoped entirely under .pec-wrap. Typography & body color inherit from
   the active theme; everything else is owned here.
   ========================================================================== */

/* ── Design tokens ──────────────────────────────────────────── */
.pec-wrap {
	--pec-purple:      #7d4fff;
	--pec-purple-dim:  rgba(125,79,255,.13);
	--pec-purple-mid:  rgba(125,79,255,.30);
	--pec-pink:        #f00069;
	--pec-pink-dim:    rgba(240,0,105,.12);
	--pec-cyan:        #00cfff;
	--pec-cyan-dim:    rgba(0,207,255,.12);
	--pec-green:       #05de99;
	--pec-green-dim:   rgba(5,222,153,.12);
	--pec-amber:       #ffaa00;
	--pec-amber-dim:   rgba(255,170,0,.12);

	--pec-bg:          #f7f4ff;
	--pec-surface:     #ffffff;
	--pec-surface-2:   #f3efff;
	--pec-border:      #d7cffa;
	--pec-border-glow: rgba(125,79,255,.25);
	--pec-text:        #241b48;
	--pec-muted:       #6c6391;

	--pec-radius:      14px;
	--pec-radius-sm:   9px;
	--pec-transition:  0.22s cubic-bezier(.16,1,.3,1);
}

/* ── Wrapper ────────────────────────────────────────────────── */
.pec-wrap {
	container-type: inline-size;
	width: 100%;
	max-width: 780px;
	margin-inline: auto;
	border: 5px solid transparent;
	background:
		linear-gradient(var(--pec-bg), var(--pec-bg)) padding-box,
		linear-gradient(135deg, #7d4fff, #00cfff) border-box;
	color: var(--pec-text);
	border-radius: var(--pec-radius);
	padding: 32px 28px 40px;
	font-size: 0.95rem;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}

@container (max-width: 560px) {
	.pec-wrap { padding: 22px 16px 32px; }
}

/* ── Section cards ──────────────────────────────────────────── */
.pec-card {
	background: var(--pec-surface);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius);
	padding: 24px 26px;
	margin-bottom: 14px;
	position: relative;
	overflow: hidden;
}

.pec-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--pec-border-glow), transparent);
}

.pec-card-title {
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--pec-muted);
	margin: 0 0 18px;
	display: flex;
	align-items: center;
	gap: 8px;
}

.pec-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	flex-shrink: 0;
	display: inline-block;
}
.pec-dot-purple { background: var(--pec-purple); box-shadow: 0 0 6px var(--pec-purple-mid); }
.pec-dot-cyan   { background: var(--pec-cyan);   box-shadow: 0 0 6px var(--pec-cyan-dim);   }

/* ── Grid layout ────────────────────────────────────────────── */
.pec-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 18px;
}

@container (max-width: 520px) {
	.pec-grid { grid-template-columns: 1fr; gap: 14px; }
}

/* ── Form fields ────────────────────────────────────────────── */
.pec-field {
	display: flex;
	flex-direction: column;
	gap: 7px;
}

.pec-field-platform {
	grid-column: 1 / -1;
}

.pec-platform-summary {
	grid-column: 1 / -1;
	background: rgba(125,79,255,.06);
	border: 1px solid rgba(125,79,255,.12);
	border-radius: var(--pec-radius-sm);
	padding: 14px 16px;
	margin-top: -2px;
}

.pec-platform-values {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 10px;
}

.pec-platform-value {
	display: flex;
	flex-direction: column;
	gap: 3px;
	padding: 8px 10px;
	background: rgba(255,255,255,.75);
	border: 1px solid rgba(125,79,255,.10);
	border-radius: 8px;
}

.pec-platform-value-label {
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--pec-muted);
}

.pec-platform-value-amount {
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--pec-text);
}

.pec-platform-note {
	margin: 10px 0 0;
	font-size: 0.76rem;
	line-height: 1.55;
	color: var(--pec-muted);
}

@container (max-width: 640px) {
	.pec-platform-values {
		grid-template-columns: 1fr 1fr;
	}
}

.pec-label {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--pec-text);
}

.pec-hint {
	font-size: 0.74rem;
	font-weight: 400;
	color: var(--pec-muted);
}

.pec-select,
.pec-input {
	box-sizing: border-box;
	width: 100%;
	min-height: 46px;
	background: var(--pec-surface-2);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius-sm);
	padding: 10px 14px;
	font: inherit;
	font-size: 0.93rem;
	font-weight: 500;
	color: var(--pec-text);
	outline: none;
	transition: border-color var(--pec-transition), box-shadow var(--pec-transition);
	-webkit-appearance: none;
	appearance: none;
}

.pec-select:focus,
.pec-input:focus {
	border-color: var(--pec-purple);
	box-shadow: 0 0 0 3px var(--pec-purple-dim);
}

.pec-select {
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 4.5l3 3 3-3' stroke='%23a7a0be' stroke-width='1.5' stroke-linecap='round' fill='none'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 13px center;
	padding-right: 34px;
}

.pec-input[type="number"] {
	-moz-appearance: textfield;
}

.pec-input[type="number"]::-webkit-outer-spin-button,
.pec-input[type="number"]::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* ── Range slider ───────────────────────────────────────────── */
.pec-range {
	-webkit-appearance: none;
	appearance: none;
	width: 100%;
	margin-top: 8px;
	height: 5px;
	border-radius: 3px;
	background: var(--pec-border);
	cursor: pointer;
	outline: none;
	border: none;
}

.pec-range::-webkit-slider-thumb {
	-webkit-appearance: none;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--pec-purple);
	border: 3px solid #ffffff;
	box-shadow: 0 0 0 2px var(--pec-purple), 0 0 10px var(--pec-purple-mid);
	cursor: pointer;
	transition: box-shadow var(--pec-transition);
}

.pec-range::-webkit-slider-thumb:hover {
	box-shadow: 0 0 0 2px var(--pec-purple), 0 0 18px var(--pec-purple-mid);
}

.pec-range::-moz-range-thumb {
	width: 16px;
	height: 16px;
	border: none;
	border-radius: 50%;
	background: var(--pec-purple);
	box-shadow: 0 0 0 2px var(--pec-purple);
	cursor: pointer;
}

.pec-range-labels {
	display: flex;
	justify-content: space-between;
	font-size: 0.7rem;
	color: var(--pec-muted);
	margin-top: 5px;
}

.pec-range-current {
	font-weight: 700;
	font-size: 0.82rem;
	color: var(--pec-purple);
}

/* ── Print info box ─────────────────────────────────────────── */
.pec-print-info {
	background: var(--pec-surface-2);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius-sm);
	padding: 11px 14px;
	font-size: 0.8rem;
	color: var(--pec-muted);
	line-height: 1.7;
}

.pec-print-info strong { color: var(--pec-text); }
.pec-print-info small  { font-size: 0.7rem; opacity: 0.65; }

/* ── Results panel ──────────────────────────────────────────── */
.pec-results {
	background: var(--pec-surface);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius);
	margin-top: 20px;
	overflow: hidden;
	position: relative;
}

.pec-results::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--pec-cyan), var(--pec-purple), var(--pec-pink));
}

.pec-results-inner {
	padding: 26px 26px 22px;
}

@container (max-width: 520px) {
	.pec-results-inner { padding: 20px 16px 18px; }
}

.pec-results-title {
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--pec-muted);
	margin: 0 0 16px;
}

/* ── Stat tiles ─────────────────────────────────────────────── */
.pec-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
	margin-bottom: 16px;
}

@container (max-width: 480px) {
	.pec-stats { grid-template-columns: 1fr 1fr; }
}

.pec-stat {
	background: var(--pec-surface-2);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius-sm);
	padding: 14px 12px 12px;
	text-align: center;
	transition: transform var(--pec-transition), border-color var(--pec-transition), box-shadow var(--pec-transition);
}

.pec-stat:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 30px rgba(78,58,140,.12);
}

.pec-stat-label {
	font-size: 0.63rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--pec-muted);
	margin-bottom: 5px;
}

.pec-stat-value {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.02em;
}

.pec-stat-sub {
	font-size: 0.67rem;
	color: var(--pec-muted);
	margin-top: 4px;
}

.pec-stat-purple { border-color: rgba(125,79,255,.3); }
.pec-stat-purple .pec-stat-value { color: var(--pec-purple); }
.pec-stat-purple:hover { border-color: var(--pec-purple); box-shadow: 0 6px 20px rgba(125,79,255,.15); }

.pec-stat-cyan { border-color: rgba(0,207,255,.2); }
.pec-stat-cyan .pec-stat-value { color: var(--pec-cyan); }
.pec-stat-cyan:hover { border-color: var(--pec-cyan); box-shadow: 0 6px 20px rgba(0,207,255,.1); }

.pec-stat-green { border-color: rgba(5,222,153,.2); }
.pec-stat-green .pec-stat-value { color: var(--pec-green); }
.pec-stat-green:hover { border-color: var(--pec-green); box-shadow: 0 6px 20px rgba(5,222,153,.1); }

.pec-stat-pink { border-color: rgba(240,0,105,.2); }
.pec-stat-pink .pec-stat-value { color: var(--pec-pink); }
.pec-stat-pink:hover { border-color: var(--pec-pink); box-shadow: 0 6px 20px rgba(240,0,105,.1); }

/* ── ROI block ──────────────────────────────────────────────── */
.pec-roi {
	background: linear-gradient(135deg, var(--pec-purple-dim), var(--pec-cyan-dim));
	border: 1px solid var(--pec-border-glow);
	border-radius: var(--pec-radius-sm);
	padding: 16px 18px;
	margin-bottom: 16px;
	display: flex;
	align-items: flex-start;
	gap: 14px;
}

.pec-roi-icon {
	font-size: 1.6rem;
	flex-shrink: 0;
	line-height: 1;
	margin-top: 1px;
}

.pec-roi-title {
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--pec-purple);
	margin-bottom: 4px;
}

.pec-roi-value {
	font-size: 1.1rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--pec-text);
	margin-bottom: 3px;
}

.pec-roi-detail {
	font-size: 0.78rem;
	color: var(--pec-muted);
	line-height: 1.5;
}

/* ── Bar chart ──────────────────────────────────────────────── */
.pec-bars { margin-bottom: 16px; }

.pec-bar-row {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 10px;
	font-size: 0.82rem;
}

.pec-bar-row:last-child { margin-bottom: 0; }

.pec-bar-label {
	width: 140px;
	flex-shrink: 0;
	color: var(--pec-muted);
	font-weight: 500;
}

@container (max-width: 480px) {
	.pec-bar-label { width: 95px; font-size: 0.75rem; }
}

.pec-bar-track {
	flex: 1;
	height: 26px;
	background: var(--pec-surface-2);
	border-radius: 7px;
	overflow: hidden;
	border: 1px solid var(--pec-border);
}

.pec-bar-fill {
	height: 100%;
	border-radius: 6px;
	transition: width 0.55s cubic-bezier(.16,1,.3,1);
	min-width: 3px;
}

.pec-bar-fill-purple { background: linear-gradient(90deg, #5636d1, var(--pec-purple)); }
.pec-bar-fill-cyan   { background: linear-gradient(90deg, #0090b3, var(--pec-cyan));   }

.pec-bar-amount {
	width: 72px;
	flex-shrink: 0;
	text-align: right;
	font-weight: 700;
	font-size: 0.88rem;
}

/* ── Pro tip ────────────────────────────────────────────────── */
.pec-tip {
	background: linear-gradient(135deg, var(--pec-purple-dim), var(--pec-pink-dim));
	border: 1px solid var(--pec-purple-mid);
	border-radius: var(--pec-radius-sm);
	padding: 14px 18px;
	font-size: 0.82rem;
	color: var(--pec-text);
	line-height: 1.7;
	margin-bottom: 14px;
}

.pec-tip-label {
	display: inline-flex;
	align-items: center;
	background: var(--pec-purple);
	color: #ffffff;
	font-size: 0.64rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	border-radius: 4px;
	padding: 2px 8px;
	margin-right: 6px;
	vertical-align: middle;
}

.pec-tip a {
	color: var(--pec-text);
	font-weight: 600;
	text-decoration: none;
	border-bottom: 1px solid currentColor;
	transition: border-color 0.2s;
}

.pec-tip a:hover { border-bottom-color: rgba(255,255,255,.7); }
.pec-tip strong  { color: var(--pec-text); }

/* ── Collapsible breakdown toggle ───────────────────────────── */
.pec-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	background: var(--pec-surface-2);
	border: 1px solid var(--pec-border);
	border-radius: var(--pec-radius-sm);
	padding: 10px 14px;
	font: inherit;
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--pec-muted);
	cursor: pointer;
	text-align: left;
	letter-spacing: 0.07em;
	text-transform: uppercase;
	transition: background var(--pec-transition), border-color var(--pec-transition), color var(--pec-transition);
}

.pec-toggle:hover {
	background: var(--pec-border);
	border-color: var(--pec-purple-mid);
	color: var(--pec-text);
}

.pec-toggle-chevron {
	width: 15px;
	height: 15px;
	flex-shrink: 0;
	transition: transform var(--pec-transition);
	opacity: 0.6;
}

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

.pec-collapse {
	overflow: hidden;
	max-height: 0;
	opacity: 0;
	transition: max-height 0.4s cubic-bezier(.16,1,.3,1), opacity 0.3s ease;
}

.pec-collapse.is-open {
	max-height: 700px;
	opacity: 1;
}

/* ── Breakdown table ────────────────────────────────────────── */
.pec-breakdown-wrap {
	padding-top: 12px;
}

.pec-breakdown {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.83rem;
}

.pec-breakdown th {
	text-align: left;
	font-size: 0.64rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--pec-muted);
	padding: 0 8px 8px;
}

.pec-breakdown th:last-child,
.pec-breakdown td:last-child { text-align: right; }

.pec-breakdown td {
	padding: 8px;
	border-top: 1px solid var(--pec-border);
	color: var(--pec-text);
	vertical-align: middle;
}

.pec-breakdown tr:first-child td { border-top: none; }

.pec-bd-label  { color: var(--pec-muted); }
.pec-bd-amount { font-weight: 600; }
.pec-bd-note   { font-size: 0.71rem; color: var(--pec-muted); opacity: 0.7; }

.pec-breakdown tr.pec-bd-total td {
	border-top: 1px solid var(--pec-border-glow);
	padding-top: 10px;
}

/* ── Disclaimer ─────────────────────────────────────────────── */
.pec-disclaimer {
	margin-top: 14px;
	padding: 11px 14px;
	border-left: 3px solid var(--pec-border-glow);
	border-radius: 0 var(--pec-radius-sm) var(--pec-radius-sm) 0;
	background: rgba(125,79,255,.05);
	font-size: 0.76rem;
	color: var(--pec-muted);
	line-height: 1.55;
}

.pec-disclaimer strong {
	display: block;
	margin-bottom: 3px;
	font-size: 0.67rem;
	letter-spacing: 0.07em;
	text-transform: uppercase;
}

/* ── Animations ─────────────────────────────────────────────── */
@keyframes pec-fade-up {
	from { opacity: 0; transform: translateY(14px); }
	to   { opacity: 1; transform: translateY(0); }
}

.pec-card:nth-child(1) { animation: pec-fade-up 0.45s cubic-bezier(.16,1,.3,1) both; }
.pec-card:nth-child(2) { animation: pec-fade-up 0.45s 0.07s cubic-bezier(.16,1,.3,1) both; }
.pec-results           { animation: pec-fade-up 0.45s 0.13s cubic-bezier(.16,1,.3,1) both; }
