/* ================================================================
   Password Crack Time Simulator — WordPress Plugin Styles v1.0.0
   All selectors are scoped to .pcs-wrapper to avoid theme conflicts.
   ================================================================ */

/* ── Design tokens (dark theme, default) ─────────────────────── */
.pcs-wrapper {
	--pcs-bg:        #0b0e17;
	--pcs-surface:   rgba(255,255,255,.04);
	--pcs-border:    rgba(255,255,255,.08);
	--pcs-text:      #e2e8f0;
	--pcs-text-dim:  #94a3b8;
	--pcs-accent:    #6366f1;
	--pcs-accent-g:  linear-gradient(135deg,#6366f1,#a855f7);
	--pcs-radius:    16px;
	--pcs-glow:      0 0 60px rgba(99,102,241,.15);
	--pcs-ring-size: 180px;
	--pcs-font:      'Inter', system-ui, sans-serif;
	box-sizing: border-box;
	font-family:  var(--pcs-font);
	color:        var(--pcs-text);
	background:   var(--pcs-bg);
	padding:      2rem 1rem 3rem;
	border-radius: var(--pcs-radius);
	background-image:
		radial-gradient(ellipse 80% 60% at 50% -20%, rgba(99,102,241,.12), transparent),
		radial-gradient(ellipse 60% 50% at 80% 100%, rgba(168,85,247,.08), transparent);
}

/* ── Light theme override ─────────────────────────────────────── */
.pcs-wrapper.pcs-theme-light {
	--pcs-bg:       #f1f5f9;
	--pcs-surface:  rgba(255,255,255,.8);
	--pcs-border:   rgba(0,0,0,.08);
	--pcs-text:     #1e293b;
	--pcs-text-dim: #64748b;
	--pcs-glow:     0 0 40px rgba(99,102,241,.1);
	background-image: none;
}

/* ── Reset within wrapper ─────────────────────────────────────── */
.pcs-wrapper *,
.pcs-wrapper *::before,
.pcs-wrapper *::after {
	box-sizing: border-box;
}

/* ── Header ───────────────────────────────────────────────────── */
.pcs-header { text-align: center; margin-bottom: 2rem; }

.pcs-title {
	font-size: clamp(1.4rem, 3.5vw, 2.1rem);
	font-weight: 800;
	background: var(--pcs-accent-g);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	letter-spacing: -.02em;
	margin: 0 0 .25rem;
	border: none;
	padding: 0;
}

.pcs-subtitle {
	color: var(--pcs-text-dim);
	font-size: .95rem;
	margin: 0;
}

/* ── Card ─────────────────────────────────────────────────────── */
.pcs-card {
	background:         var(--pcs-surface);
	border:             1px solid var(--pcs-border);
	border-radius:      var(--pcs-radius);
	padding:            2rem;
	backdrop-filter:    blur(24px);
	-webkit-backdrop-filter: blur(24px);
	box-shadow:         var(--pcs-glow);
	margin-bottom:      1.5rem;
	transition:         box-shadow .3s;
}

.pcs-card:hover { box-shadow: 0 0 80px rgba(99,102,241,.22); }

/* ── Input group ──────────────────────────────────────────────── */
.pcs-input-wrap { margin-bottom: 1.75rem; }

.pcs-label {
	display: block;
	font-size: .8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--pcs-text-dim);
	margin-bottom: .5rem;
}

.pcs-input-row { display: flex; }

.pcs-pw-input,
input.pcs-pw-input,
input.pcs-pw-input[type="password"],
input.pcs-pw-input[type="text"] {
	flex: 1;
	font-family: var(--pcs-font);
	font-size: 1rem;
	padding: .75rem 1rem;
	border: 1px solid var(--pcs-border);
	border-radius: 10px 0 0 10px;
	background: rgba(255,255,255,.03);
	color: #ffffff !important;
	-webkit-text-fill-color: #ffffff !important;
	caret-color: #ffffff;
	outline: none;
	transition: border-color .2s;
	/* reset possible theme overrides */
	box-shadow: none;
	min-height: unset;
}

.pcs-theme-light .pcs-pw-input {
	background: #fff;
	color: #1e293b;
}

.pcs-pw-input:focus { border-color: var(--pcs-accent); }

.pcs-toggle-vis {
	border: 1px solid var(--pcs-border);
	border-left: none;
	border-radius: 0 10px 10px 0;
	background: rgba(255,255,255,.05);
	color: var(--pcs-text-dim);
	cursor: pointer;
	padding: 0 .85rem;
	font-size: 1.1rem;
	transition: background .2s;
	display: flex;
	align-items: center;
	line-height: 1;
}

.pcs-toggle-vis:hover { background: rgba(255,255,255,.12); }

/* ── Strength ─────────────────────────────────────────────────── */
.pcs-strength-row {
	display: flex;
	align-items: center;
	gap: .75rem;
	margin-bottom: 1.5rem;
}

.pcs-strength-badge {
	font-size: .75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	padding: .3rem .75rem;
	border-radius: 999px;
	color: #fff;
	background: #334155;
	transition: background .4s, transform .2s;
	white-space: nowrap;
}

.pcs-strength-badge.pcs-pop { transform: scale(1.12); }

.pcs-strength-label {
	color: var(--pcs-text-dim);
	font-size: .85rem;
}

/* ── Entropy ring ─────────────────────────────────────────────── */
.pcs-ring-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-bottom: 1.75rem;
}

.pcs-ring-wrap {
	position: relative;
	width:  var(--pcs-ring-size);
	height: var(--pcs-ring-size);
}

.pcs-ring-wrap svg {
	transform: rotate(-90deg);
	width: 100%; height: 100%;
}

.pcs-ring-bg {
	fill: none;
	stroke: rgba(255,255,255,.06);
	stroke-width: 10;
}

.pcs-ring-fg {
	fill: none;
	stroke-width: 10;
	stroke-linecap: round;
	transition: stroke-dashoffset .6s cubic-bezier(.4,0,.2,1);
}

.pcs-ring-text {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

.pcs-ring-value {
	font-size: 2rem;
	font-weight: 800;
	line-height: 1;
	color: var(--pcs-text);
}

.pcs-ring-unit {
	font-size: .7rem;
	color: var(--pcs-text-dim);
	margin-top: 2px;
	text-transform: uppercase;
	letter-spacing: .08em;
}

/* ── Detail grid ──────────────────────────────────────────────── */
.pcs-detail-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .65rem 1.2rem;
	margin-bottom: 1.75rem;
}

.pcs-item { display: flex; flex-direction: column; gap: 2px; }

.pcs-lbl {
	font-size: .7rem;
	color: var(--pcs-text-dim);
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight: 600;
}

.pcs-val { font-size: .95rem; font-weight: 600; }

/* ── Attack vectors ───────────────────────────────────────────── */
.pcs-attack-title {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 1.25rem;
	display: flex;
	align-items: center;
	gap: .45rem;
	border: none;
	padding: 0;
	color: var(--pcs-text);
}

.pcs-attack { margin-bottom: 1.35rem; }
.pcs-attack:last-of-type { margin-bottom: 0; }

.pcs-attack-header {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: .35rem;
}

.pcs-attack-name {
	font-size: .8rem;
	font-weight: 600;
	display: flex;
	align-items: center;
	gap: .4rem;
}

.pcs-attack-time {
	font-size: .8rem;
	font-weight: 700;
	color: var(--pcs-accent);
	text-align: right;
}

.pcs-bar-track {
	height: 8px;
	border-radius: 999px;
	background: rgba(255,255,255,.06);
	overflow: hidden;
	position: relative;
}

.pcs-theme-light .pcs-bar-track { background: rgba(0,0,0,.08); }

.pcs-bar-fill {
	height: 100%;
	border-radius: 999px;
	width: 0%;
	transition: width .8s cubic-bezier(.4,0,.2,1), background .5s;
}

.pcs-bar-fill.pcs-active::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
	animation: pcs-shimmer 1.8s infinite;
}

@keyframes pcs-shimmer {
	0%   { transform: translateX(-100%); }
	100% { transform: translateX(100%); }
}

/* ── Speed reference ──────────────────────────────────────────── */
.pcs-speed-ref {
	font-size: .72rem;
	color: var(--pcs-text-dim);
	border-top: 1px solid var(--pcs-border);
	padding-top: 1rem;
	margin-top: 1.2rem;
	line-height: 1.7;
}

.pcs-speed-ref strong { color: var(--pcs-text); }

/* ── Disclaimer ───────────────────────────────────────────────── */
.pcs-disclaimer {
	text-align: center;
	font-size: .75rem;
	color: var(--pcs-text-dim);
	line-height: 1.6;
	margin-top: .5rem;
}

.pcs-disclaimer strong { color: var(--pcs-text); }

/* ── Responsive ───────────────────────────────────────────────── */
@media (max-width: 480px) {
	.pcs-card { padding: 1.4rem; }
	.pcs-wrapper { --pcs-ring-size: 150px; }
	.pcs-detail-grid { grid-template-columns: 1fr; }
}
