/* ==========================================================================
   Pinellas Criminal Law Pro — Homepage Section Styles
   ========================================================================== */

/* HERO */
.pcl-hero { background: linear-gradient(180deg, #0b1220 0%, #0f172a 60%, #11203b 100%); color: #fff; position: relative; overflow: hidden; padding: clamp(72px, 11vw, 140px) 0 clamp(72px, 9vw, 120px); }
.pcl-hero__bg { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: .25; z-index: 0; }
.pcl-hero__bg-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(11,18,32,.85), rgba(11,18,32,.95)); z-index: 0; }
.pcl-hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(28px, 5vw, 64px); align-items: center; }
.pcl-hero__title { font-family: var(--pcl-font-display); font-size: clamp(2.2rem, 5.5vw, 4rem); line-height: 1.05; letter-spacing: -0.03em; margin: 14px 0 16px; color: #fff; font-weight: 800; }
.pcl-hero__subtitle { font-size: clamp(1rem, 1.4vw, 1.18rem); color: #cbd5e1; margin: 0 0 28px; max-width: 620px; }
.pcl-hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
.pcl-hero__emergency { display: inline-flex; align-items: center; gap: 12px; margin-top: 18px; padding: 12px 18px; background: rgba(185,28,28,.15); border: 1px solid rgba(185,28,28,.35); border-radius: 999px; color: #fff; font-weight: 600; font-size: .92rem; transition: background var(--pcl-trans), border-color var(--pcl-trans); }
.pcl-hero__emergency:hover { background: rgba(185,28,28,.25); color: #fff; border-color: rgba(185,28,28,.6); }
.pcl-hero__emergency-pulse { width: 10px; height: 10px; border-radius: 50%; background: #ef4444; box-shadow: 0 0 0 4px rgba(239,68,68,.3); animation: pclPulse 1.6s infinite; }

.pcl-hero__trust { list-style: none; padding: 0; margin: 26px 0 0; display: flex; flex-wrap: wrap; gap: 14px; }
.pcl-hero__trust li { display: inline-flex; align-items: center; gap: 8px; color: #cbd5e1; font-size: .88rem; }
.pcl-trust-check { color: #34d399; font-weight: 800; }

.pcl-hero__quickstart { margin-top: 28px; display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.pcl-hero__quickstart-label { color: #94a3b8; font-size: .85rem; font-weight: 600; }
.pcl-hero__quickstart ul { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.pcl-hero__quickstart a { display: inline-block; padding: 8px 14px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); border-radius: 999px; color: #fff; font-size: .85rem; font-weight: 600; transition: background var(--pcl-trans); }
.pcl-hero__quickstart a:hover { background: rgba(255,255,255,.12); color: #fff; }

.pcl-hero__disclaimer { color: #94a3b8; font-size: .82rem; margin: 22px 0 0; max-width: 620px; }

/* Hero side panel */
.pcl-panel--hero {
	background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
	border: 1px solid rgba(255,255,255,.12); border-radius: 22px;
	padding: 26px; backdrop-filter: blur(14px);
	color: #fff; position: relative; overflow: hidden;
}
.pcl-panel--hero::after { content: ''; position: absolute; inset: 0; background: radial-gradient(600px 200px at 100% 0%, rgba(192,138,62,.18), transparent 60%); pointer-events: none; }
.pcl-panel__head { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.pcl-panel__chip { display: inline-flex; align-self: flex-start; padding: 4px 10px; background: rgba(192,138,62,.18); color: #facc15; font-weight: 700; font-size: .72rem; border-radius: 999px; text-transform: uppercase; letter-spacing: .1em; }
.pcl-panel__title { font-family: var(--pcl-font-display); font-weight: 800; font-size: 1.2rem; }
.pcl-panel__list { list-style: none; padding: 0; margin: 0 0 16px; display: grid; gap: 8px; }
.pcl-panel__list li { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: rgba(255,255,255,.05); border-radius: 12px; font-size: .92rem; color: #e2e8f0; }
.pcl-panel__step { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 8px; background: rgba(185,28,28,.25); color: #fbbf24; font-weight: 800; font-size: .75rem; }
.pcl-panel__meter { display: flex; flex-direction: column; gap: 6px; margin-top: 12px; }
.pcl-panel__meter-bar { height: 8px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden; }
.pcl-panel__meter-bar span { display: block; height: 100%; width: var(--w, 0%); background: linear-gradient(90deg, var(--pcl-red), #f59e0b); border-radius: 999px; }
.pcl-panel__meter small { color: #94a3b8; font-size: .75rem; }
.pcl-panel__foot { margin: 18px 0 0; padding: 10px 12px; background: rgba(185,28,28,.18); border-left: 3px solid #ef4444; border-radius: 8px; color: #fecaca; font-size: .8rem; }

/* GUIDES */
.pcl-guides { background: linear-gradient(180deg, #f5f8fc, #fff); }

/* CHARGE EXPLORER */
.pcl-explorer__tabs { display: inline-flex; padding: 4px; background: #fff; border: 1px solid var(--pcl-line); border-radius: 999px; margin: 0 auto 24px; box-shadow: var(--pcl-shadow-sm); }
.pcl-tab { padding: 10px 18px; border: 0; background: transparent; font-weight: 600; color: var(--pcl-slate); border-radius: 999px; transition: background var(--pcl-trans), color var(--pcl-trans); }
.pcl-tab.is-active { background: var(--pcl-navy); color: #fff; }
.pcl-explorer__panels { margin-top: 16px; }
.pcl-explorer__panel { animation: pclFade .35s ease both; }
.pcl-explorer__panel[hidden] { display: none; }
@keyframes pclFade { from { opacity: 0; transform: translateY(6px);} to { opacity: 1; transform: translateY(0);} }

.pcl-archetype {
	position: relative; text-align: left;
	background: #fff; border: 1px solid var(--pcl-line); border-radius: 18px; padding: 18px;
	display: flex; flex-direction: column; gap: 8px; transition: all var(--pcl-trans);
	cursor: pointer;
}
.pcl-archetype:hover { transform: translateY(-2px); box-shadow: var(--pcl-shadow); border-color: var(--pcl-navy); }
.pcl-archetype__icon { font-size: 1.6rem; }
.pcl-archetype__name { font-family: var(--pcl-font-display); font-weight: 700; color: var(--pcl-navy); }
.pcl-archetype__desc { font-size: .88rem; color: var(--pcl-muted); }
.pcl-archetype__pin { position: absolute; top: 12px; right: 12px; width: 24px; height: 24px; border-radius: 50%; background: var(--pcl-red); color: #fff; font-size: .8rem; display: none; align-items: center; justify-content: center; }
.pcl-archetype[aria-pressed="true"] { border-color: var(--pcl-red); box-shadow: 0 0 0 3px rgba(185,28,28,.12); }
.pcl-archetype[aria-pressed="true"] .pcl-archetype__pin { display: inline-flex; }

.pcl-charge { background: #fff; border: 1px solid var(--pcl-line); border-radius: 18px; padding: 22px; display: flex; flex-direction: column; gap: 12px; }
.pcl-charge__head { display: flex; flex-direction: column; gap: 6px; }
.pcl-charge__title { margin: 0; font-family: var(--pcl-font-display); color: var(--pcl-navy); font-size: 1.1rem; }
.pcl-charge__pill { font-size: .75rem; color: var(--pcl-muted); }
.pcl-charge__desc { color: var(--pcl-slate); margin: 0; font-size: .94rem; }
.pcl-charge__terms { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.pcl-charge__range { background: #f8fafc; border-radius: 12px; padding: 10px 12px; font-size: .85rem; color: var(--pcl-slate); display: grid; gap: 4px; }
.pcl-charge__foot { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: auto; }
.pcl-charge__foot small { color: var(--pcl-muted); font-size: .78rem; }

.pcl-explorer__active { margin-top: 24px; padding: 12px 16px; background: rgba(185,28,28,.06); border: 1px dashed rgba(185,28,28,.25); border-radius: 12px; display: inline-flex; align-items: center; gap: 12px; }
.pcl-explorer__active-label { color: var(--pcl-slate); font-weight: 600; }
.pcl-explorer__active-value { color: var(--pcl-red); font-weight: 800; }

/* COMPARISON */
.pcl-compare__stack { display: grid; gap: 28px; }
.pcl-compare__card { background: #fff; border: 1px solid var(--pcl-line); border-radius: var(--pcl-radius-lg); padding: 24px; box-shadow: var(--pcl-shadow-sm); }
.pcl-compare__title { font-family: var(--pcl-font-display); color: var(--pcl-navy); margin: 0 0 12px; }
.pcl-compare__scroll { overflow-x: auto; }
.pcl-compare__table { width: 100%; border-collapse: separate; border-spacing: 0; min-width: 520px; }
.pcl-compare__table thead th { position: sticky; top: 0; background: var(--pcl-navy); color: #fff; text-align: left; padding: 12px 14px; font-weight: 700; font-size: .9rem; }
.pcl-compare__table thead th:first-child { border-top-left-radius: 10px; }
.pcl-compare__table thead th:last-child { border-top-right-radius: 10px; }
.pcl-compare__table td, .pcl-compare__table th[scope="row"] { padding: 12px 14px; border-bottom: 1px solid var(--pcl-line); vertical-align: top; font-size: .92rem; }
.pcl-compare__rowhead { font-weight: 700; color: var(--pcl-navy); background: #f8fafc; }
.pcl-compare__table tr:hover .pcl-compare__cell, .pcl-compare__table tr:hover .pcl-compare__rowhead { background: rgba(185,28,28,.04); }
.pcl-compare__hint { color: var(--pcl-muted); font-size: .8rem; margin: 12px 0 0; }

/* FAQ */
.pcl-accordion { display: grid; gap: 10px; }
.pcl-accordion__item { background: #fff; border: 1px solid var(--pcl-line); border-radius: 14px; overflow: hidden; }
.pcl-accordion__btn { width: 100%; text-align: left; background: transparent; border: 0; padding: 18px 20px; display: flex; justify-content: space-between; align-items: center; gap: 12px; font-family: var(--pcl-font-display); font-weight: 700; color: var(--pcl-navy); font-size: 1rem; }
.pcl-accordion__btn:hover { background: #f8fafc; }
.pcl-accordion__icon { width: 28px; height: 28px; border-radius: 50%; background: var(--pcl-soft); color: var(--pcl-red); display: inline-flex; align-items: center; justify-content: center; font-weight: 800; transition: transform var(--pcl-trans); flex-shrink: 0; }
.pcl-accordion__btn[aria-expanded="true"] .pcl-accordion__icon { transform: rotate(45deg); background: var(--pcl-red); color: #fff; }
.pcl-accordion__panel { padding: 0 20px 20px; color: var(--pcl-slate); animation: pclFade .25s ease both; }

/* CONSULTATION */
.pcl-consult { background: linear-gradient(180deg, #f5f8fc, #fff); }
.pcl-consult__shell { display: grid; grid-template-columns: 1.4fr 1fr; gap: 24px; }
.pcl-consult__panel { background: #fff; border: 1px solid var(--pcl-line); border-radius: var(--pcl-radius-lg); padding: 28px; box-shadow: var(--pcl-shadow-sm); }
.pcl-consult__panel--calm { background: linear-gradient(180deg, #fff, #f5f8fc); }
.pcl-consult__form { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
.pcl-consult__form .pcl-field--wide { grid-column: 1 / -1; }
.pcl-consult__actions { grid-column: 1 / -1; display: flex; gap: 10px; flex-wrap: wrap; }
.pcl-consult__cards { display: grid; gap: 12px; margin-top: 16px; }
.pcl-consult__cards .pcl-consult__rescard { background: #f8fafc; border: 1px solid var(--pcl-line); border-radius: 12px; padding: 14px; }
.pcl-consult__cards h4 { margin: 0 0 6px; font-family: var(--pcl-font-display); color: var(--pcl-navy); font-size: 1rem; }
.pcl-consult__cards ul { margin: 0; padding-left: 18px; color: var(--pcl-slate); font-size: .92rem; }
.pcl-consult__checklist { list-style: none; padding: 0; margin: 16px 0; display: grid; gap: 8px; }
.pcl-consult__checklist label { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: #fff; border: 1px solid var(--pcl-line); border-radius: 10px; cursor: pointer; font-size: .92rem; }
.pcl-consult__checklist input { accent-color: var(--pcl-red); }
.pcl-consult__warm { margin: 8px 0 14px; color: var(--pcl-muted); font-size: .85rem; }
.pcl-consult__bottomstrip { margin-top: 28px; padding: 22px 24px; background: var(--pcl-navy); color: #fff; border-radius: var(--pcl-radius-lg); display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; }
.pcl-consult__bottomstrip h3 { color: #fff; margin: 0; }
.pcl-consult__bottomstrip p { color: #cbd5e1; margin: 0; }

/* TRUST */
.pcl-trust { background: #fff; }
.pcl-trust-card { background: linear-gradient(180deg, #fff, #f5f8fc); border: 1px solid var(--pcl-line); border-radius: var(--pcl-radius-lg); padding: 22px; display: flex; flex-direction: column; gap: 8px; transition: transform var(--pcl-trans); }
.pcl-trust-card:hover { transform: translateY(-3px); box-shadow: var(--pcl-shadow); }
.pcl-trust-card__icon { font-size: 1.6rem; }
.pcl-trust-card h3 { margin: 0; font-family: var(--pcl-font-display); color: var(--pcl-navy); }
.pcl-trust-card p { margin: 0; color: var(--pcl-slate); font-size: .92rem; }
.pcl-trust__final { text-align: center; margin: 28px auto 0; color: var(--pcl-muted); font-size: .88rem; max-width: 760px; }
