/* =====================================================
   Paywall Manager v2 — Frontend CSS
   ===================================================== */

:root {
	--pwm-red:        #B8272C;
	--pwm-red-dark:   #961f23;
	--pwm-primary:    #1a1a2e;
	--pwm-muted:      #6b7280;
	--pwm-border:     #e5e7eb;
	--pwm-bg:         #ffffff;
	--pwm-radius:     12px;
	--pwm-shadow:     0 24px 64px rgba(0,0,0,0.22);
	--pwm-err-bg:     #fef2f2;
	--pwm-err-bd:     #fecaca;
	--pwm-err-tx:     #dc2626;
	--pwm-ok-bg:      #f0fdf4;
	--pwm-ok-bd:      #bbf7d0;
	--pwm-ok-tx:      #16a34a;
}

/* ===================================================
   PULSANTI — regola unica, massima priorità
   Copre: .pwm-btn, varianti, button#pwm-submit,
          .pwm-open-login, .pwm-banner-logout, a-btn
   =================================================== */

.pwm-btn,
.pwm-btn-primary,
.pwm-btn-ghost,
.pwm-btn-lg,
.pwm-open-login,
button.pwm-open-login,
a.pwm-open-login,
#pwm-submit,
#pwm-logout,
.pwm-banner-logout {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: .5rem 1.25rem !important;
	border-radius: 6px !important;
	font-size: .875rem !important;
	font-weight: 600 !important;
	cursor: pointer !important;
	border: 2px solid #B8272C !important;
	background: #B8272C !important;
	color: #ffffff !important;
	text-decoration: none !important;
	line-height: 1.2 !important;
	white-space: nowrap !important;
	-webkit-appearance: none !important;
	appearance: none !important;
	box-sizing: border-box !important;
	transition: background .18s, border-color .18s !important;
	box-shadow: none !important;
	text-shadow: none !important;
	letter-spacing: normal !important;
	font-family: inherit !important;
}

.pwm-btn:hover,
.pwm-btn:focus,
.pwm-btn-primary:hover,
.pwm-btn-primary:focus,
.pwm-btn-ghost:hover,
.pwm-btn-ghost:focus,
.pwm-open-login:hover,
.pwm-open-login:focus,
button.pwm-open-login:hover,
button.pwm-open-login:focus,
a.pwm-open-login:hover,
a.pwm-open-login:focus,
#pwm-submit:hover,
#pwm-submit:focus,
#pwm-logout:hover,
#pwm-logout:focus,
.pwm-banner-logout:hover,
.pwm-banner-logout:focus {
	background: #961f23 !important;
	border-color: #961f23 !important;
	color: #ffffff !important;
	text-decoration: none !important;
	outline: none !important;
}

.pwm-btn-w { width: 100% !important; }

#pwm-submit:disabled,
.pwm-btn:disabled {
	opacity: .55 !important;
	cursor: not-allowed !important;
}

/* ===================================================
   Banner "articoli rimanenti"
   =================================================== */

.pwm-banner {
	display: flex;
	align-items: center;
	gap: .75rem;
	padding: .875rem 1.25rem;
	margin-bottom: 1.5rem;
	background: #fffbeb;
	border: 1px solid #fcd34d;
	border-left: 4px solid #f59e0b;
	border-radius: 8px;
	font-size: .9rem;
	color: #78350f;
	line-height: 1.5;
	flex-wrap: wrap;
}

.pwm-banner a {
	color: #B8272C !important;
	font-weight: 600;
	text-decoration: none;
}

.pwm-banner a:hover { text-decoration: underline; }

/* Banner utente loggato — verde */
.pwm-banner-logged {
	background: #f0fdf4;
	border-color: #bbf7d0;
	border-left-color: #16a34a;
	color: #14532d;
	justify-content: space-between;
}

.pwm-banner-sub { flex: 1; }

/* ===================================================
   Wrapper contenuto bloccato
   =================================================== */

.pwm-wrapper { position: relative; }

.pwm-excerpt {
	position: relative;
	overflow: hidden;
	max-height: 260px;
}

.pwm-excerpt::after {
	content: '';
	position: absolute;
	inset: auto 0 0 0;
	height: 130px;
	background: linear-gradient(to bottom, transparent, #fff 85%);
	pointer-events: none;
}

/* ===================================================
   Overlay paywall
   =================================================== */

.pwm-overlay {
	position: relative;
	z-index: 5;
	margin-top: -40px;
	padding: 0 1rem 1.5rem;
}

.pwm-overlay-box {
	max-width: 540px;
	margin: 0 auto;
	padding: 2.5rem 2rem;
	background: var(--pwm-bg);
	border: 1px solid var(--pwm-border);
	border-radius: var(--pwm-radius);
	box-shadow: 0 8px 30px rgba(0,0,0,.1);
	text-align: center;
}

.pwm-overlay-logo {
	max-height: 48px;
	width: auto;
	margin-bottom: 1.25rem;
}

.pwm-lock {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3.5rem;
	height: 3.5rem;
	background: #f3f4f6;
	border-radius: 50%;
	margin-bottom: 1rem;
	color: var(--pwm-primary);
}

.pwm-lock svg { width: 1.75rem; height: 1.75rem; }

.pwm-lock-warning {
	background: #fef3c7;
	color: #92400e;
}

.pwm-overlay-box h3 {
	margin: 0 0 .625rem;
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--pwm-primary);
}

.pwm-overlay-box > p {
	margin: 0 0 1.75rem;
	color: var(--pwm-muted);
	font-size: .975rem;
	line-height: 1.6;
}

.pwm-overlay-actions {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: .75rem;
}

.pwm-not-sub { font-size: .875rem; color: var(--pwm-muted); margin: 0; }
.pwm-not-sub a { color: #B8272C; font-weight: 600; text-decoration: none; }

/* ===================================================
   Modale login
   =================================================== */

.pwm-modal {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}

.pwm-modal[hidden] { display: none !important; }

.pwm-modal-bg {
	position: absolute;
	inset: 0;
	background: rgba(10,10,25,.8);
	backdrop-filter: blur(3px);
}

.pwm-modal-box {
	position: relative;
	background: var(--pwm-bg);
	border-radius: var(--pwm-radius);
	box-shadow: var(--pwm-shadow);
	padding: 2.5rem;
	width: 100%;
	max-width: 420px;
	max-height: 92vh;
	overflow-y: auto;
	animation: pwm-in .22s ease;
}

@keyframes pwm-in {
	from { opacity:0; transform: translateY(-14px) scale(.97); }
	to   { opacity:1; transform: translateY(0) scale(1); }
}

.pwm-modal-x {
	position: absolute;
	top: 1rem; right: 1rem;
	background: none;
	border: none;
	font-size: 1.25rem;
	color: var(--pwm-muted);
	cursor: pointer;
	padding: .25rem;
	line-height: 1;
	border-radius: 4px;
	transition: color .15s, background .15s;
}
.pwm-modal-x:hover { color: var(--pwm-primary); background: #f3f4f6; }

.pwm-modal-logo {
	display: block;
	max-height: 44px;
	width: auto;
	margin: 0 auto 1.25rem;
}

.pwm-modal-box h2 {
	margin: 0 0 .375rem;
	font-size: 1.3rem;
	font-weight: 700;
	text-align: center;
	color: var(--pwm-primary);
}

.pwm-modal-box > p {
	margin: 0 0 1.5rem;
	text-align: center;
	color: var(--pwm-muted);
	font-size: .9rem;
}

.pwm-modal-foot {
	margin-top: 1.125rem;
	text-align: center;
	font-size: .875rem;
	color: var(--pwm-muted);
}

.pwm-modal-foot a { color: #B8272C; font-weight: 600; text-decoration: none; }

/* ===================================================
   Form
   =================================================== */

.pwm-field { margin-bottom: 1rem; }

.pwm-field label {
	display: block;
	font-size: .875rem;
	font-weight: 600;
	color: var(--pwm-primary);
	margin-bottom: .35rem;
}

.pwm-field input[type="email"],
.pwm-field input[type="password"] {
	width: 100%;
	padding: .65rem .875rem;
	border: 1.5px solid var(--pwm-border);
	border-radius: 8px;
	font-size: 1rem;
	background: #fafafa;
	color: var(--pwm-primary);
	transition: border-color .18s, box-shadow .18s;
	box-sizing: border-box;
}

.pwm-field input:focus {
	outline: none;
	border-color: #B8272C;
	box-shadow: 0 0 0 3px rgba(184,39,44,.14);
	background: #fff;
}

.pwm-pass-wrap { position: relative; display: flex; }
.pwm-pass-wrap input { padding-right: 2.75rem; }

/* Pulsante occhio — nessun effetto */
.pwm-eye {
	position: absolute;
	right: .625rem;
	top: 50%;
	transform: translateY(-50%);
	background: none !important;
	border: none !important;
	box-shadow: none !important;
	outline: none !important;
	cursor: pointer;
	color: var(--pwm-muted);
	padding: .2rem;
	display: flex;
	align-items: center;
	transition: none !important;
}
.pwm-eye:hover,
.pwm-eye:focus {
	background: none !important;
	border: none !important;
	color: var(--pwm-muted) !important;
	box-shadow: none !important;
	outline: none !important;
}
.pwm-eye svg { width: 1.1rem; height: 1.1rem; }

/* ===================================================
   Alert
   =================================================== */

.pwm-alert {
	padding: .7rem 1rem;
	border-radius: 8px;
	font-size: .875rem;
	margin-bottom: 1rem;
	line-height: 1.5;
}

.pwm-alert-err { background: var(--pwm-err-bg); border: 1px solid var(--pwm-err-bd); color: var(--pwm-err-tx); }
.pwm-alert-ok  { background: var(--pwm-ok-bg);  border: 1px solid var(--pwm-ok-bd);  color: var(--pwm-ok-tx); }

/* ===================================================
   Standalone login
   =================================================== */

.pwm-standalone { max-width: 460px; margin: 0 auto; }

.pwm-stand-form-wrap {
	background: var(--pwm-bg);
	border: 1px solid var(--pwm-border);
	border-radius: var(--pwm-radius);
	padding: 2rem;
	box-shadow: 0 4px 16px rgba(0,0,0,.06);
}

.pwm-stand-form-wrap h2 { margin: 0 0 1.5rem; font-size: 1.4rem; font-weight: 700; }

.pwm-stand-logo {
	display: block;
	max-height: 44px;
	width: auto;
	margin: 0 auto 1.25rem;
}

.pwm-logged-box {
	background: var(--pwm-ok-bg);
	border: 1px solid var(--pwm-ok-bd);
	border-radius: var(--pwm-radius);
	padding: 1.5rem 2rem;
}

/* ===================================================
   Responsive
   =================================================== */

@media (max-width: 600px) {
	.pwm-modal-box,
	.pwm-overlay-box,
	.pwm-stand-form-wrap { padding: 1.75rem 1.25rem; }

	.pwm-overlay-box h3 { font-size: 1.15rem; }

	.pwm-banner-logged { flex-direction: column; align-items: flex-start; }
}
