/* Tarifs — styles pricing (pr-*) extraits de la maquette de référence */
/* Le Terminal — pricing styles (full page + homepage band). */

/* ---------- PLAN CARDS ---------- */
.pr-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 360px)); gap: 26px; justify-content: center; }
@media (max-width: 760px) {
  .pr-grid { grid-template-columns: 1fr; }
}
.pr-card { position: relative; display: flex; flex-direction: column; gap: 18px; padding: 32px 30px 28px; background: var(--bg-elevated); border: 1px solid var(--border-subtle); border-radius: var(--r-lg); box-shadow: var(--shadow-md); transition: border-color var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.pr-card:hover { transform: translateY(-3px); border-color: var(--border); }
.pr-card.is-pro { background: linear-gradient(180deg, rgba(127,184,232,0.07), var(--bg-elevated) 45%); border-color: var(--accent-glow); box-shadow: 0 0 0 1px var(--accent-glow), 0 24px 64px rgba(0,0,0,0.6), 0 0 44px var(--accent-glow-soft); }
.pr-card.is-pro:hover { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-glow), 0 28px 70px rgba(0,0,0,0.65), 0 0 54px var(--accent-glow); }
.pr-card__flag { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: #07090C; background: var(--accent); padding: 4px 12px; border-radius: var(--r-pill); box-shadow: 0 0 18px var(--accent-glow); white-space: nowrap; }
.pr-card__head { display: flex; flex-direction: column; gap: 4px; }
.pr-card__name { font-family: var(--font-display); text-transform: uppercase; font-size: 1.6rem; color: var(--text-title); letter-spacing: 0.02em; line-height: 1; }
.is-pro .pr-card__name { color: var(--accent-bright); }
.pr-card__tag { font-size: 13px; color: var(--text-muted); }
.pr-card__price { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.pr-card__amount { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: clamp(2.4rem, 4vw, 3.2rem); font-weight: 600; color: var(--text-title); line-height: 1; }
.pr-card__per { font-family: var(--font-mono); font-size: 12px; color: var(--text-muted); }
.pr-card__save { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--bull); }
.pr-card__save--mute { color: var(--text-muted); }
.pr-card__feats { list-style: none; margin: 4px 0 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.pr-card__feats li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.45; color: var(--text-body); }
.pr-check { flex-shrink: 0; margin-top: 2px; }
.pr-card__cta { margin-top: auto; padding-top: 10px; }
.pr-card__note { text-align: center; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--text-muted); }
/* ---------- HOMEPAGE BAND ---------- */
.pr-band { position: relative; max-width: var(--container); margin: 0 auto; padding: var(--sp-9) 40px; }
.pr-band__head { display: flex; flex-direction: column; align-items: center; gap: 14px; text-align: center; margin-bottom: var(--sp-6); }
.pr-band__title { font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-display-2); color: var(--text-title); margin: 0; line-height: 1; }
.pr-band__lede { margin: 0; color: var(--text-body); font-size: 1.05rem; max-width: 50ch; }
.pr-band__more { display: flex; justify-content: center; margin-top: 26px; }
.pr-band__link { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--accent); transition: color var(--dur-fast) var(--ease-out), gap var(--dur-fast) var(--ease-out); }
.pr-band__link:hover { color: var(--accent-bright); gap: 12px; }
/* ---------- PRICING PAGE ---------- */
.pr-hero { position: relative; padding: calc(var(--chrome-h, 64px) + 90px) 24px 50px; display: flex; flex-direction: column; align-items: center; gap: 18px; text-align: center; overflow: hidden; }
.pr-hero__halo { position: absolute; top: -45%; left: 50%; transform: translateX(-50%); width: 75%; height: 110%; background: radial-gradient(ellipse 50% 55% at 50% 0%, var(--accent-glow) 0%, transparent 60%); filter: blur(16px); pointer-events: none; opacity: 0.55; }
.pr-hero__title { position: relative; margin: 0; font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-display-1); line-height: 0.95; letter-spacing: 0.01em; }
.pr-hero__lede { position: relative; margin: 0; max-width: 58ch; color: var(--text-body); font-size: clamp(1rem, 1.4vw, 1.15rem); line-height: 1.6; }
.pr-toggle { position: relative; display: inline-flex; gap: 4px; padding: 4px; border: 1px solid var(--border-subtle); border-radius: var(--r-pill); background: var(--bg-surface); margin-top: 8px; }
.pr-toggle__opt { font-family: var(--font-text); font-size: 13px; font-weight: 600; color: var(--text-muted); background: transparent; border: none; border-radius: var(--r-pill); padding: 9px 20px; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; transition: all var(--dur-fast) var(--ease-out); }
.pr-toggle__opt em { font-style: normal; font-family: var(--font-mono); font-size: 10.5px; color: var(--bull); }
.pr-toggle__opt.is-on { color: #07090C; background: var(--accent); box-shadow: 0 0 18px var(--accent-glow); }
.pr-toggle__opt.is-on em { color: rgba(7,9,12,0.75); }
.pr-plans { padding: 30px 40px var(--sp-8); }
.pr-why { max-width: var(--container); margin: 0 auto; padding: 0 40px var(--sp-8); display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
@media (max-width: 860px) {
  .pr-why { grid-template-columns: 1fr; }
}
.pr-why__item { display: flex; flex-direction: column; gap: 10px; padding: 26px; border: 1px solid var(--border-subtle); border-radius: var(--r-lg); background: var(--bg-surface); }
.pr-why__n { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; color: var(--accent); }
.pr-why__item h3 { margin: 0; font-size: 1.12rem; font-weight: 600; color: var(--text-title); }
.pr-why__item p { margin: 0; font-size: 0.93rem; line-height: 1.6; color: var(--text-body); }
.pr-compare { max-width: 900px; margin: 0 auto; padding: 0 40px var(--sp-8); }
.pr-compare__title { font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-display-2); color: var(--text-title); margin: 0 0 var(--sp-6); text-align: center; line-height: 1; }
.pr-table { border: 1px solid var(--border-subtle); border-radius: var(--r-lg); overflow: hidden; background: var(--bg-surface); }
.pr-table__row { display: grid; grid-template-columns: 1.6fr 1fr 1fr; align-items: center; padding: 12px 22px; border-bottom: 1px solid var(--border-subtle); }
.pr-table__row:last-child { border-bottom: none; }
.pr-table__row--head { background: var(--bg-void); font-family: var(--font-display); text-transform: uppercase; font-size: 1rem; letter-spacing: 0.04em; color: var(--text-title); padding: 16px 22px; }
.pr-table__row--head .pr-table__pro { color: var(--accent-bright); }
.pr-table__row--head > span:not(:first-child) { text-align: center; }
.pr-table__group { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); padding: 14px 22px 10px; border-bottom: 1px solid var(--border-subtle); background: rgba(127,184,232,0.04); }
.pr-table__feat { font-size: 14px; color: var(--text-body); }
.pr-table__cell { text-align: center; font-family: var(--font-mono); font-size: 13px; color: var(--text-body); font-variant-numeric: tabular-nums; }
.pr-table__cell.pr-table__pro { color: var(--text-title); font-weight: 600; }
.pr-dash { color: var(--text-muted); opacity: 0.5; }
@media (max-width: 640px) {
  .pr-table__row { grid-template-columns: 1.3fr 0.8fr 0.8fr; padding: 12px 14px; }
  .pr-table__feat { font-size: 12.5px; }
}
.pr-faq { max-width: 760px; margin: 0 auto; padding: 0 40px var(--sp-8); }
.pr-faq__title { font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-display-2); color: var(--text-title); margin: 0 0 var(--sp-6); text-align: center; line-height: 1; }
.pr-faq__list { display: flex; flex-direction: column; gap: 10px; }
.pr-faq__item { border: 1px solid var(--border-subtle); border-radius: var(--r-lg); background: var(--bg-surface); overflow: hidden; transition: border-color var(--dur-fast) var(--ease-out); }
.pr-faq__item.is-open { border-color: var(--border); }
.pr-faq__q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; text-align: left; font-family: var(--font-text); font-size: 15px; font-weight: 600; color: var(--text-title); background: transparent; border: none; padding: 18px 22px; cursor: pointer; }
.pr-faq__chev { display: inline-flex; color: var(--text-muted); transition: transform var(--dur-base) var(--ease-out); }
.pr-faq__item.is-open .pr-faq__chev { transform: rotate(180deg); color: var(--accent); }
.pr-faq__a { display: grid; grid-template-rows: 0fr; transition: grid-template-rows var(--dur-base) var(--ease-out); }
.pr-faq__item.is-open .pr-faq__a { grid-template-rows: 1fr; }
.pr-faq__a p { overflow: hidden; margin: 0; padding: 0 22px; font-size: 14px; line-height: 1.65; color: var(--text-body); }
.pr-faq__item.is-open .pr-faq__a p { padding-bottom: 20px; }
.pr-final { display: flex; flex-direction: column; align-items: center; gap: 16px; text-align: center; padding: var(--sp-7) 24px var(--sp-9); }
.pr-final__title { margin: 0; font-family: var(--font-display); text-transform: uppercase; font-size: var(--fs-display-2); line-height: 1; }
.pr-final__lede { margin: 0; color: var(--text-body); font-size: 1.05rem; }
.pr-final__cta { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; margin-top: 6px; }
