/* assets/css/fa.css */

:root{
  --bg:#ffffff;
  --bg-2:#ffffff;
  --bg-3:#ffffff;

  --surface:#ffffff;
  --surface-2:#ffffff;
  --surface-3:#ffffff;

  --text:#0d1630;
  --text-soft:#263556;
  --text-faint:#4d5f82;

  --line:rgba(10,20,45,.22);
  --line-strong:rgba(10,20,45,.34);

  --primary:#19145e;
  --primary-2:#241d86;
  --primary-3:#3b31d8;
  --primary-soft:#eef0ff;

  --secondary:#5f66da;
  --secondary-2:#7c85f2;
  --accent:#2d28a8;
  --accent-2:#5f66da;
  --sky:#6778ff;

  --ok:#168f59;
  --danger:#d83f5b;

  --shadow:0 18px 40px rgba(36,29,134,.08);
  --shadow-soft:0 10px 24px rgba(13,22,48,.05);
  --shadow-card:0 14px 34px rgba(13,22,48,.06);

  --radius:28px;
  --radius-md:22px;
  --radius-sm:18px;

  --serif:"Cormorant Garamond", serif;
  --sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;

  --max:1180px;
  --navH:82px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background:#fff;
  overflow-x:hidden;
  padding-top:var(--navH);
}

img{max-width:100%;display:block}
button,input,textarea{font:inherit}
a{color:inherit}
button{border:none}

.container{
  width:min(100% - 32px, var(--max));
  margin:0 auto;
}

/* ===== BACKDROP ===== */
.fa-backdrop{
  position:fixed;
  inset:0;
  z-index:-1;
  overflow:hidden;
  background:#fff;
}

.fa-network{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
  background:#fff;
}

body.hide-chapelet .fa-network{
  display:none !important;
}

.fa-ritual-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s ease;
  mix-blend-mode:screen;
  filter:saturate(1.04) contrast(1.02) brightness(1.06);
}

.fa-ritual-veil{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 50% 45%, rgba(59,49,216,.05), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.08));
  opacity:0;
  transition:opacity .35s ease;
  pointer-events:none;
}

.fa-ritual-glow{
  position:absolute;
  inset:-6%;
  background:
    radial-gradient(circle at 50% 50%, rgba(59,49,216,.10), transparent 24%),
    radial-gradient(circle at 70% 35%, rgba(95,102,218,.08), transparent 22%),
    radial-gradient(circle at 30% 65%, rgba(25,20,94,.06), transparent 22%);
  filter:blur(24px);
  opacity:0;
  transition:opacity .35s ease;
  pointer-events:none;
}

body.no-ritual .fa-ritual-bg,
body.no-ritual .fa-ritual-veil,
body.no-ritual .fa-ritual-glow{
  opacity:0;
}



body:not(.no-ritual) .fa-ritual-bg{
  opacity:.34;
}

body:not(.no-ritual) .fa-ritual-veil{
  opacity:1;
}

body:not(.no-ritual) .fa-ritual-glow{
  opacity:1;
}



#tirage .tirage-shell{
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(8px);
}



body.is-ritual-tirage .fa-ritual-bg{
  opacity:.62 !important;
}

body.is-ritual-tirage .fa-ritual-veil{
  opacity:1 !important;
}

body.is-ritual-tirage .fa-ritual-glow{
  opacity:1 !important;
}

/* ===== NAV ===== */
.fa-nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:rgba(255,255,255,.90);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(10,20,45,.14);
  box-shadow:none;
}

.nav-shell{
  min-height:var(--navH);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
  text-decoration:none;
  min-width:0;
}

.brand-mark{
  width:52px;
  height:52px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(25,20,94,.08), rgba(59,49,216,.10));
  border:1px solid rgba(10,20,45,.18);
  display:grid;
  place-items:center;
  flex-shrink:0;
}

.brand-logo{
  width:34px;
  height:34px;
  object-fit:contain;
}

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.05;
  min-width:0;
}

.brand-text strong{
  color:var(--text);
  font-size:1rem;
  letter-spacing:.01em;
  font-weight:800;
}

.brand-text small{
  color:var(--text-soft);
  font-size:.74rem;
  margin-top:4px;
  font-weight:600;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:10px;
}

.nav-links a{
  text-decoration:none;
  padding:10px 14px;
  border-radius:999px;
  color:var(--text);
  transition:background .2s ease, color .2s ease, transform .2s ease;
  font-weight:700;
}

.nav-links a:hover,
.nav-links a.is-active{
  background:rgba(36,29,134,.08);
  color:var(--primary);
}

.nav-actions{
  display:flex;
  align-items:center;
  gap:10px;
}

.theme-toggle,
.nav-burger{
  width:46px;
  height:46px;
  border-radius:16px;
  border:1px solid rgba(10,20,45,.18);
  background:#fff;
  color:var(--text);
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:background .2s ease, transform .2s ease;
  box-shadow:none;
}

.theme-toggle:hover,
.nav-burger:hover{
  background:#f7f8ff;
  transform:translateY(-1px);
}

.theme-ic{
  font-size:18px;
  line-height:1;
}

.nav-burger{
  display:none;
  padding:0;
}

.nav-burger span{
  display:block;
  width:18px;
  height:2px;
  background:var(--text);
  margin:2px auto;
  border-radius:999px;
}

.nav-drawer{
  display:none;
  padding:0 0 16px;
}

.nav-drawer.is-open{
  display:block;
}

.drawer-card{
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  border-radius:24px;
  padding:10px;
  display:grid;
  gap:8px;
  box-shadow:none;
}

.drawer-link{
  text-decoration:none;
  padding:14px 16px;
  border-radius:16px;
  background:rgba(36,29,134,.03);
  color:var(--text);
  font-weight:700;
}

.drawer-link:hover{
  background:rgba(36,29,134,.08);
}

/* ===== PAGES ===== */
.page{display:none}
.page.is-active{display:block}

.section{
  display:none;
  padding:46px 0;
}

.section.is-active{
  display:block;
}

/* ===== HERO ===== */
.hero{
  padding:30px 0 18px;
}

.hero-wrap{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:30px;
  align-items:center;
}

.hero-copy{
  padding:10px 0;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(25,20,94,.05), rgba(59,49,216,.08));
  border:1px solid rgba(36,29,134,.18);
  color:var(--primary);
  margin-bottom:16px;
  font-size:.88rem;
  font-weight:800;
  box-shadow:none;
}

.hero h1{
  margin:0 0 14px;
  font-family:var(--serif);
  font-size:clamp(2.9rem, 5vw, 5rem);
  line-height:.92;
  letter-spacing:-.02em;
  color:#081226;
}

.hero-lead{
  margin:0;
  color:#22314e;
  font-size:1.06rem;
  line-height:1.75;
  max-width:62ch;
  font-weight:500;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}

.hero-meta span{
  padding:10px 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  color:#233250;
  box-shadow:none;
  font-weight:700;
}

.hero-visual{
  position:relative;
}

.mobile-showcase{
  position:relative;
  min-height:640px;
  display:grid;
  place-items:center;
}

.phone-mock{
  width:min(100%, 360px);
  border-radius:38px;
  padding:12px;
  background:linear-gradient(180deg, #ffffff, #fbfbff);
  border:1px solid rgba(10,20,45,.18);
  box-shadow:none;
  position:relative;
}

.phone-top{
  width:110px;
  height:26px;
  border-radius:0 0 18px 18px;
  background:#edf1ff;
  margin:0 auto 10px;
}

.phone-screen{
  border-radius:30px;
  padding:16px;
  min-height:560px;
  background:linear-gradient(180deg, #ffffff, #fafbff 100%);
  border:1px solid rgba(10,20,45,.14);
  display:flex;
  flex-direction:column;
  gap:14px;
}

.mock-header{
  display:flex;
  justify-content:flex-start;
}

.mock-pill{
  display:inline-flex;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(36,29,134,.08);
  color:var(--primary);
  font-size:.8rem;
  font-weight:700;
}

.mock-card{
  background:#fff;
  border:1px solid rgba(10,20,45,.16);
  border-radius:22px;
  padding:16px;
  box-shadow:none;
}

.mock-card.glow{
  background:linear-gradient(135deg, rgba(25,20,94,.05), rgba(59,49,216,.08));
}

.mock-card p{
  margin:0;
  color:var(--text);
  line-height:1.55;
  font-weight:600;
}

.mock-title{
  font-weight:800;
  margin-bottom:12px;
  color:var(--text);
}

.mock-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

.mock-grid span{
  min-height:52px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:#f4f6ff;
  border:1px solid rgba(10,20,45,.16);
  font-weight:800;
  color:var(--text);
}

.mock-grid span.on{
  background:linear-gradient(135deg, rgba(25,20,94,.12), rgba(59,49,216,.16));
  color:var(--primary);
}

.mini-pay{
  margin-top:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.mini-pay strong{
  color:var(--text);
  font-weight:800;
}

.mini-pay small{
  display:block;
  color:var(--text-soft);
  margin-top:4px;
  font-weight:700;
}

.mini-pay button{
  border:0;
  border-radius:16px;
  padding:12px 14px;
  font-weight:800;
  color:#fff;
  background:linear-gradient(135deg, var(--primary), var(--primary-3));
  box-shadow:none;
}

.floating-chip{
  position:absolute;
  padding:10px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  box-shadow:none;
  font-size:.85rem;
  color:var(--text);
  backdrop-filter:blur(10px);
  font-weight:700;
}

.chip-a{left:0;top:50px}
.chip-b{right:6px;top:140px}
.chip-c{left:24px;bottom:70px}

/* ===== QUICK ===== */
.home-quick{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  padding-bottom:18px;
}

.quick-card{
  text-decoration:none;
  border-radius:24px;
  padding:20px 16px;
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  box-shadow:none;
  min-height:120px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:10px;
  transition:transform .2s ease, background .2s ease;
}

.quick-card:hover{
  transform:translateY(-3px);
  background:#fcfcff;
}

.quick-ic{
  font-size:1.6rem;
  color:var(--primary);
}

.quick-label{
  font-weight:800;
  color:var(--text);
}

/* ===== COMMON ===== */
.section-head{
  margin-bottom:18px;
}

.section-kicker{
  display:inline-block;
  color:var(--primary);
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-bottom:8px;
  font-weight:800;
}

.section-head h2{
  margin:0 0 8px;
  font-family:var(--serif);
  font-size:clamp(2rem, 4vw, 3rem);
  line-height:1;
  color:#081226;
}

.section-head p{
  margin:0;
  color:#22314e;
  line-height:1.6;
  font-weight:500;
}

.feature-band,
.info-grid,
.pretre-layout,
.books-grid,
.contact-grid{
  display:grid;
  gap:16px;
}

.feature-band{
  grid-template-columns:repeat(4,1fr);
}

.feature-box,
.info-panel,
.content-card,
.media-card,
.tirage-shell,
.diagnostic-shell,
.payment-hero,
.reveal-card,
.prete-bio,
.prete-media,
.book-card,
.contact-shell,
.drawer-card{
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  border-radius:28px;
  box-shadow:none;
  backdrop-filter:blur(8px);
}

.feature-box{
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:8px;
}

.feature-box strong{
  font-size:1.45rem;
  color:var(--primary);
  font-weight:800;
}

.feature-box span{
  color:var(--text);
  font-weight:700;
}

.content-card{
  padding:24px;
  margin-top:16px;
}

.lead-block{
  margin:0 0 14px;
  font-size:1.03rem;
  line-height:1.75;
  color:var(--text);
  font-weight:500;
}

.nice-list{
  margin:0;
  padding-left:20px;
  color:#22314e;
  line-height:1.8;
  font-weight:500;
}

.inline-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:18px;
}

.info-grid{
  grid-template-columns:1fr 1fr;
}

.info-panel{
  padding:22px;
}

.info-panel h3,
.media-card h3,
.prete-bio h3,
.prete-media h3,
.book-body h3{
  margin:0 0 12px;
  font-size:1.2rem;
  color:#081226;
  font-weight:800;
}

.media-card{
  padding:20px;
  margin-top:16px;
}

.media-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:14px;
}

.media-head p{
  margin:6px 0 0;
  color:#22314e;
  font-weight:500;
}

.media-pager{
  display:flex;
  align-items:center;
  gap:10px;
}

.media-count{
  color:var(--text-soft);
  min-width:90px;
  text-align:center;
  font-weight:700;
}

.player-shell,
.vid-frame,
.diag-display,
.diag-locker,
.reveal-line,
input,
textarea{
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  color:var(--text);
}

.player-shell,
.vid-frame{
  overflow:hidden;
  border-radius:22px;
  box-shadow:none;
}

.player-shell iframe,
.vid-frame iframe,
#cadrePlayer{
  width:100%;
  aspect-ratio:16/9;
  border:0;
  display:block;
}

.yt-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
}

.yt-tile{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid rgba(10,20,45,.18);
  background:#fff;
  cursor:pointer;
  box-shadow:none;
  transition:transform .18s ease, border-color .18s ease;
}

.yt-tile:hover{
  transform:translateY(-2px);
  border-color:rgba(36,29,134,.30);
}

.yt-thumb{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
}

.yt-play{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  font-size:34px;
  color:#fff;
  text-shadow:0 12px 40px rgba(0,0,0,.35);
}

.yt-tile.is-on{
  outline:2px solid rgba(49,39,163,.44);
}

/* ===== TIRAGE ===== */
.tirage-shell{
  padding:18px;
}

.tirage-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:16px;
}

.tirage-top-left{
  display:flex;
  flex-direction:column;
  gap:14px;
  width:100%;
}

.tirage-top strong{
  display:block;
  font-size:1.05rem;
  color:#081226;
  font-weight:800;
}

.tirage-top small{
  display:block;
  margin-top:4px;
  color:var(--text-soft);
  font-weight:700;
}

.tirage-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  width:100%;
}

.ab-picker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px;
  border-radius:20px;
  background:linear-gradient(135deg, rgba(25,20,94,.04), rgba(59,49,216,.06));
  border:1px solid rgba(36,29,134,.14);
  margin-left:auto;
}

.ab-picker-label{
  padding:0 8px 0 6px;
  color:var(--primary);
  font-weight:800;
  white-space:nowrap;
}

.ab-picker-sep{
  color:var(--text-soft);
  font-weight:700;
  padding:0 2px;
}

.ab-pick-btn{
  min-width:56px;
  min-height:46px;
  padding:10px 16px;
  border-radius:16px;
}

.fa-board{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
}

.fa-cell{
  min-height:96px;
  border-radius:22px;
  padding:14px;
  background:#fff;
  border:1px solid rgba(10,20,45,.20);
  opacity:.68;
  transition:background .18s ease, opacity .18s ease, border-color .18s ease, transform .18s ease;
  box-shadow:none;
}

.fa-cell-inner{
  width:100%;
  min-height:66px;
  border-radius:18px;
  border:1px solid rgba(10,20,45,.18);
  background:#f5f6ff;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  padding:14px;
}

.fa-cell-value{
  width:100%;
  text-align:center;
  font-size:1.15rem;
  line-height:1;
  font-weight:900;
  color:#7c8294;
  min-height:20px;
}

.fa-cell.is-active{
  opacity:1;
  background:linear-gradient(135deg, rgba(25,20,94,.06), rgba(59,49,216,.09));
  border-color:rgba(36,29,134,.26);
  transform:translateY(-1px);
}

.fa-cell.is-active .fa-cell-inner{
  border-color:rgba(36,29,134,.24);
  background:#f7f8ff;
}

.fa-cell.is-locked{
  opacity:1;
  background:#fff;
}

.fa-cell.is-locked .fa-cell-inner{
  background:linear-gradient(135deg, rgba(25,20,94,.05), rgba(59,49,216,.08));
  border-color:rgba(36,29,134,.18);
}

.fa-cell.is-picked-a .fa-cell-value,
.fa-cell.is-picked-b .fa-cell-value{
  color:#081226;
}

.fa-cell.is-empty .fa-cell-value::before{
  content:"";
}

/* ===== DIAGNOSTIC ===== */
.diag-orbit{
  display:flex;
  justify-content:center;
  margin-bottom:12px;
}

.fa-spin{
  display:flex;
  justify-content:center;
}

.fa-spin-ic{
  width:56px;
  height:56px;
  border-radius:50%;
  display:grid;
  place-items:center;
  font-size:1.2rem;
  background:#fff;
  border:1px solid rgba(36,29,134,.20);
  color:var(--primary);
  box-shadow:none;
  animation:faSpin 1.2s linear infinite;
}

@keyframes faSpin{
  to{transform:rotate(360deg)}
}

.diagnostic-shell{
  padding:20px;
}

.diag-display{
  min-height:180px;
  border-radius:22px;
  padding:20px;
  line-height:1.9;
  font-size:1.03rem;
  color:#132241;
  box-shadow:none;
  font-weight:500;
}

.diag-locker{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  padding:16px 18px;
  border-radius:20px;
  box-shadow:none;
}

.diag-lock-left{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--text);
  font-weight:700;
}

.diag-lock-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.lock{
  font-size:1.2rem;
}

/* ===== PAIEMENT ===== */
.payment-hero{
  padding:26px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  background:linear-gradient(135deg, #fff, #fafbff);
}

.payment-copy strong{
  display:block;
  font-size:1.15rem;
  color:#081226;
  font-weight:800;
}

.payment-price{
  font-family:var(--serif);
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:1;
  margin:10px 0 10px;
  color:#081226;
}

.payment-copy p{
  margin:0;
  color:#22314e;
  font-weight:500;
}

.payment-action{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}

.payment-action small{
  color:var(--text-soft);
  font-weight:700;
}

/* ===== REVELATION ===== */
.reveal-card{
  padding:24px;
}

.reveal-line{
  border-radius:18px;
  padding:16px 18px;
  font-family:var(--serif);
  font-size:1.2rem;
  line-height:1.6;
  box-shadow:none;
  color:#081226;
}

.reveal-line + .reveal-line{
  margin-top:12px;
}

.blur-line{
  filter:blur(4px);
  opacity:.7;
  user-select:none;
}

/* ===== PRETRE ===== */
.pretre-layout{
  grid-template-columns:.9fr 1.1fr;
}

.prete-bio,
.prete-media{
  padding:22px;
}

.prete-bio p,
.prete-media p{
  color:#22314e;
  line-height:1.75;
  font-weight:500;
}

.pretre-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}

/* ===== BOOKS ===== */
.books-grid{
  grid-template-columns:1fr 1fr;
}

.book-card{
  padding:18px;
  display:grid;
  grid-template-columns:140px 1fr;
  gap:18px;
}

.book-cover{
  border-radius:20px;
  min-height:180px;
  background:
    linear-gradient(180deg, rgba(25,20,94,.08), rgba(59,49,216,.08)),
    #fff;
  border:1px solid rgba(10,20,45,.18);
}

.book-body p{
  margin:0;
  color:#22314e;
  line-height:1.7;
  font-weight:500;
}

/* ===== CONTACT ===== */
.contact-shell{
  padding:22px;
}

.contact-grid{
  grid-template-columns:1fr 1fr;
}

.field label{
  display:block;
  margin:0 0 8px;
  font-size:.95rem;
  color:#081226;
  font-weight:800;
}

.field + .field{
  margin-top:0;
}

input,textarea{
  width:100%;
  border-radius:18px;
  padding:14px 16px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

input::placeholder,
textarea::placeholder{
  color:rgba(77,95,130,.72);
}

input:focus,
textarea:focus{
  border-color:rgba(49,39,163,.34);
  box-shadow:none;
  background:#fff;
}

.check-row{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:16px;
  color:#081226;
  font-weight:700;
}

.check-row input{
  width:18px;
  height:18px;
  box-shadow:none;
}

.contact-actions{
  margin-top:18px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}

/* ===== BUTTONS ===== */
.btn{
  border:0;
  text-decoration:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 18px;
  border-radius:18px;
  transition:transform .2s ease, box-shadow .2s ease, filter .2s ease;
  font-weight:800;
}

.btn:hover{
  transform:translateY(-2px);
}

.btn-lg{
  min-height:54px;
  padding:14px 22px;
}

.btn-xl{
  min-height:58px;
  padding:16px 24px;
}

.btn-primary{
  color:#fff;
  background:linear-gradient(135deg, var(--primary) 0%, var(--primary-2) 46%, var(--primary-3) 100%);
  box-shadow:none;
}

.btn-primary:hover{
  box-shadow:none;
  filter:saturate(1.05);
}

.btn-soft{
  color:var(--primary);
  background:linear-gradient(135deg, rgba(25,20,94,.05), rgba(59,49,216,.08));
  border:1px solid rgba(36,29,134,.14);
}

.btn-soft:hover{
  box-shadow:none;
}

/* ===== FOOTER ===== */
.footer{
  padding:28px 0 34px;
  border-top:1px solid rgba(10,20,45,.14);
  background:#fff;
}

.footer-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

.muted{
  color:var(--text-soft);
}

/* ===== FLOATING ACTIONS ===== */
.wa-float{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom));
  z-index:999;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(10,20,45,.18);
  color:var(--text);
  box-shadow:none;
  backdrop-filter:blur(12px);
}

.wa-ic{
  width:34px;
  height:34px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(49,39,163,.10);
  color:var(--primary);
}

.wa-txt{
  font-weight:800;
  font-size:.95rem;
}

.m-cta{
  display:none;
}

/* ===== REVEAL ===== */
.reveal{
  opacity:0;
  transform:translateY(18px);
  transition:opacity .6s ease, transform .6s ease;
}

.reveal.is-in{
  opacity:1;
  transform:none;
}

/* ===== THEME VARIANTS ===== */
body.theme-light{
  background:#fff;
}

body:not(.theme-light){
  background:#fff;
}

body:not(.theme-light) .fa-backdrop,
body:not(.theme-light) .fa-network{
  background:#fff;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px){
  .hero-wrap{
    grid-template-columns:1fr;
  }

  .mobile-showcase{
    min-height:auto;
  }

  .feature-band{
    grid-template-columns:repeat(2,1fr);
  }

  .pretre-layout,
  .books-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width: 900px){
  .nav-links,
  .nav-start{
    display:none;
  }

  .nav-burger{
    display:grid;
  }

  .home-quick{
    grid-template-columns:repeat(2,1fr);
  }

  .info-grid,
  .contact-grid{
    grid-template-columns:1fr;
  }

  .yt-grid{
    grid-template-columns:repeat(3,1fr);
  }

  .pretre-grid{
    grid-template-columns:1fr;
  }

  .payment-hero,
  .tirage-top,
  .diag-locker,
  .footer-row{
    flex-direction:column;
    align-items:flex-start;
  }

  .payment-action{
    align-items:stretch;
    width:100%;
  }

  .payment-action .btn{
    width:100%;
  }

  .m-cta{
    display:grid;
    place-items:center;
    position:fixed;
    left:16px;
    bottom:calc(16px + env(safe-area-inset-bottom));
    z-index:999;
    width:58px;
    height:58px;
    border-radius:50%;
    text-decoration:none;
    background:linear-gradient(135deg, var(--primary), var(--primary-3));
    color:#fff;
    box-shadow:none;
  }

  .m-cta-ic{
    font-size:1.2rem;
  }
}

@media (max-width: 640px){
  body{
    padding-top:74px;
  }

  .container{
    width:min(100% - 20px, var(--max));
  }

  .nav-shell{
    min-height:74px;
  }

  .brand-mark{
    width:46px;
    height:46px;
    border-radius:16px;
  }

  .brand-logo{
    width:30px;
    height:30px;
  }

  .brand-text small{
    display:none;
  }

  .hero{
    padding:14px 0 14px;
  }

  .hero h1{
    font-size:clamp(2.2rem, 11vw, 3.4rem);
    line-height:.95;
  }

  .hero-lead{
    font-size:.98rem;
  }

  .hero-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .hero-actions .btn{
    width:100%;
  }

  .hero-meta{
    display:grid;
    grid-template-columns:1fr;
  }

  .phone-mock{
    width:100%;
    max-width:340px;
    padding:10px;
    border-radius:32px;
  }

  .phone-screen{
    min-height:520px;
    border-radius:24px;
    padding:14px;
  }

  .floating-chip{
    font-size:.76rem;
    padding:8px 12px;
  }

  .chip-a{left:2px;top:26px}
  .chip-b{right:2px;top:92px}
  .chip-c{left:12px;bottom:44px}

  .section{
    padding:30px 0;
  }

  .feature-band{
    grid-template-columns:1fr;
  }

  .yt-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .fa-board{
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:10px;
  }

  .fa-cell{
    min-height:76px;
    padding:10px;
    border-radius:18px;
  }

  .fa-cell-inner{
    min-height:48px;
    padding:10px;
    border-radius:14px;
  }

  .fa-cell-value{
    font-size:1rem;
  }

  .tirage-actions{
    width:100%;
    gap:10px;
  }

  .ab-picker{
    margin-left:0;
    width:100%;
    justify-content:space-between;
    gap:6px;
    padding:6px;
  }

  .ab-picker-label{
    padding:0 6px 0 4px;
    font-size:.95rem;
  }

  .ab-picker-sep{
    padding:0;
    font-size:.92rem;
  }

  .ab-pick-btn{
    flex:1;
    min-width:0;
    min-height:42px;
    padding:10px 12px;
    border-radius:14px;
  }

  .book-card{
    grid-template-columns:1fr;
  }

  .wa-txt{
    display:none;
  }

  .wa-float{
    padding:10px;
  }
}