/* ============================================================
   ÉDIFICE — ceremonial layer on top of shadcn/ui tokens.
   Sober shadcn base; restrained antique-gold reserved strictly
   for sovereign / ceremonial moments (Serment, niveaux, sceaux).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

:root{
  /* Deeper, antique sovereign gold — harmonised with --brand-amber */
  --gold:        oklch(0.74 0.12 84);
  --gold-deep:   oklch(0.58 0.10 80);
  --gold-soft:   oklch(0.93 0.04 88);
  --gold-line:   oklch(0.86 0.06 86);
  /* Ceremonial ink (near-black with a warm cast) */
  --ink:         oklch(0.20 0.012 80);
  --ink-deep:    oklch(0.155 0.01 80);
  --font-read:   "Spectral", Georgia, "Times New Roman", serif;
}

/* ---------------- layout helpers ---------------- */
.stack{display:flex;flex-direction:column;}
.row{display:flex;align-items:center;}
.between{display:flex;align-items:center;justify-content:space-between;}
.wrap{flex-wrap:wrap;}
.grow{flex:1;}
.muted{color:var(--muted-foreground);}
.mono{font-family:var(--font-mono);}
.center{text-align:center;}
.tnum{font-variant-numeric:tabular-nums;}

/* ---------------- gold accent primitives ---------------- */
.badge-gold{background:var(--gold-soft);color:var(--gold-deep);border:1px solid var(--gold-line);}
.badge-eveil{background:color-mix(in oklch,var(--primary) 12%,#fff);color:oklch(0.42 0.12 152);border:1px solid color-mix(in oklch,var(--primary) 30%,#fff);}
.btn-gold{background:var(--gold-deep);color:#fff;}
.btn-gold:hover{background:color-mix(in oklch,var(--gold-deep) 88%,#000);}
.seal-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold-line),transparent);}
.kbd{font-family:var(--font-mono);font-size:12px;background:var(--muted);border:1px solid var(--border);
  border-bottom-width:2px;border-radius:6px;padding:2px 6px;}

/* ============================================================
   RITUEL D'ENTRÉE — Serment du Bâtisseur
   ============================================================ */
.ritual{min-height:100%;display:flex;align-items:stretch;background:var(--ink-deep);color:oklch(0.92 0.01 80);
  position:relative;overflow:hidden;}
.ritual::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 80% at 50% -10%,oklch(0.30 0.03 80) 0%,transparent 60%);
  pointer-events:none;}
.ritual-aside{width:42%;flex:none;padding:56px 52px;display:flex;flex-direction:column;justify-content:space-between;
  border-right:1px solid oklch(0.30 0.02 80 / .6);position:relative;z-index:1;}
.ritual-main{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;position:relative;z-index:1;overflow-y:auto;}
.ritual-card{width:100%;max-width:560px;}
.ritual-mark{display:inline-flex;align-items:center;gap:12px;}
.ritual-mark .glyph{width:40px;height:40px;border:1px solid var(--gold);color:var(--gold);border-radius:8px;
  display:flex;align-items:center;justify-content:center;}
.ritual-mark .wm{font-weight:600;letter-spacing:.32em;font-size:15px;color:oklch(0.95 0.01 80);}
.eyebrow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:600;}
.oath-display{font-family:var(--font-read);font-weight:400;letter-spacing:-0.01em;line-height:1.18;}
.oath-text{font-family:var(--font-read);font-size:17px;line-height:1.72;color:oklch(0.86 0.01 80);}
.oath-text em{color:var(--gold);font-style:italic;}
.oath-clause{display:flex;gap:14px;padding:15px 0;border-bottom:1px solid oklch(0.30 0.02 80 / .5);}
.oath-clause .n{font-family:var(--font-mono);font-size:12px;color:var(--gold);padding-top:3px;flex:none;width:24px;}
.oath-clause .t{font-family:var(--font-read);font-size:15.5px;line-height:1.55;color:oklch(0.84 0.01 80);}

.darkcard{background:oklch(0.22 0.012 80);border:1px solid oklch(0.34 0.02 80 / .8);border-radius:14px;}
.dark-input{height:42px;width:100%;padding:0 14px;background:oklch(0.17 0.01 80);border:1px solid oklch(0.34 0.02 80);
  border-radius:9px;color:oklch(0.95 0.01 80);font-family:inherit;font-size:14px;}
.dark-input::placeholder{color:oklch(0.55 0.01 80);}
.dark-input:focus-visible{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px oklch(0.74 0.12 84 / .25);}
.dark-label{font-size:12px;font-weight:500;color:oklch(0.70 0.01 80);margin-bottom:7px;display:block;}

/* fingerprint pad */
.fp-pad{position:relative;width:128px;height:148px;border:1px dashed oklch(0.40 0.02 80);border-radius:14px;
  display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;
  background:oklch(0.18 0.01 80);transition:border-color .25s;flex:none;}
.fp-pad:hover{border-color:var(--gold);}
.fp-pad.scanning{border-style:solid;border-color:var(--gold);}
.fp-pad.done{border-style:solid;border-color:var(--primary);}
.fp-print{width:78px;height:96px;color:oklch(0.42 0.02 80);transition:color .3s;}
.fp-pad.done .fp-print{color:var(--primary);}
.fp-fill{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(0deg,oklch(0.74 0.12 84 / .35),transparent);
  transition:height .1s linear;pointer-events:none;}
.fp-line{position:absolute;left:8px;right:8px;height:2px;background:var(--gold);box-shadow:0 0 12px 2px oklch(0.74 0.12 84 / .6);
  border-radius:2px;}

/* signature line */
.sign-line{border-bottom:1px solid oklch(0.42 0.02 80);height:54px;display:flex;align-items:flex-end;padding-bottom:6px;}
.sign-name{font-family:var(--font-read);font-style:italic;font-size:26px;color:var(--gold);}

/* ============================================================
   LISEUSE — secure streaming reader
   ============================================================ */
.reader-shell{position:absolute;inset:0;display:flex;flex-direction:column;background:oklch(0.985 0.003 80);}
.reader-bar{height:52px;flex:none;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;
  padding:0 18px;background:color-mix(in oklch,var(--background) 88%,transparent);backdrop-filter:blur(8px);z-index:6;}
.reader-scroll{flex:1;overflow-y:auto;position:relative;}
.reader-page{max-width:680px;margin:0 auto;padding:64px 32px 120px;position:relative;}
.prose{font-family:var(--font-read);color:var(--ink);}
.prose .chap-no{font-family:var(--font-mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep);}
.prose h1{font-size:34px;font-weight:500;letter-spacing:-0.02em;line-height:1.12;margin:10px 0 8px;}
.prose .lede{font-size:19px;line-height:1.7;color:var(--muted-foreground);font-style:italic;margin:0 0 28px;}
.prose p{font-size:18.5px;line-height:1.82;margin:0 0 22px;text-wrap:pretty;}
.prose p:first-letter{}
.prose .drop::first-letter{font-size:62px;float:left;line-height:.84;padding:6px 12px 0 0;color:var(--gold-deep);font-weight:500;}
.prose blockquote{margin:30px 0;padding:6px 0 6px 24px;border-left:2px solid var(--gold-line);
  font-style:italic;font-size:19px;color:var(--ink);}

/* dynamic watermark overlay (streaming protection) */
.watermark{position:absolute;inset:0;pointer-events:none;z-index:4;overflow:hidden;
  display:flex;flex-wrap:wrap;align-content:flex-start;gap:0;opacity:.5;}
.wm-tile{transform:rotate(-30deg);font-family:var(--font-mono);font-size:11px;color:oklch(0.55 0.01 80 / .14);
  white-space:nowrap;padding:40px 26px;letter-spacing:.04em;user-select:none;}
.no-select{user-select:none;-webkit-user-select:none;}

.reader-foot{height:46px;flex:none;border-top:1px solid var(--border);display:flex;align-items:center;
  justify-content:space-between;padding:0 18px;font-size:12px;color:var(--muted-foreground);background:var(--background);}
.progress-track{height:3px;background:var(--muted);border-radius:3px;overflow:hidden;flex:1;max-width:280px;}
.progress-fill{height:100%;background:var(--primary);border-radius:3px;}

/* table of contents drawer */
.toc{position:absolute;top:52px;bottom:0;left:0;width:300px;background:var(--background);border-right:1px solid var(--border);
  z-index:5;padding:16px;overflow-y:auto;transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow-lg);}
.toc.open{transform:translateX(0);}
.toc-item{display:flex;gap:12px;padding:11px 12px;border-radius:9px;cursor:pointer;align-items:baseline;}
.toc-item:hover{background:var(--muted);}
.toc-item.active{background:var(--accent);}
.toc-item.locked{opacity:.55;}
.toc-item .ix{font-family:var(--font-mono);font-size:12px;color:var(--muted-foreground);flex:none;width:22px;}

/* ============================================================
   GENERIC PAGE SCAFFOLD (inside app shell)
   ============================================================ */
.page-head{display:flex;flex-direction:column;gap:4px;margin-bottom:4px;}
.page-title{font-size:24px;font-weight:600;letter-spacing:-0.025em;}
.page-sub{color:var(--muted-foreground);font-size:14px;}
.section-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-foreground);font-weight:600;}

/* ============================================================
   BIBLIOTHÈQUE
   ============================================================ */
.lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;}
.book{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--card);cursor:pointer;
  transition:box-shadow .18s,transform .18s,border-color .18s;}
.book:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:oklch(0.86 0 0);}
.book-cover{aspect-ratio:3/4;display:flex;flex-direction:column;justify-content:space-between;padding:22px;color:#fff;position:relative;}
.cover-eveil{background:linear-gradient(160deg,oklch(0.30 0.04 158),oklch(0.20 0.02 158));}
.cover-souverain{background:linear-gradient(160deg,var(--ink),oklch(0.16 0.01 80));}
.book-cover .corner{position:absolute;inset:10px;border:1px solid rgba(255,255,255,.16);border-radius:8px;pointer-events:none;}
.book-cover .glyph{width:30px;height:30px;border:1px solid var(--gold);color:var(--gold);border-radius:6px;display:flex;align-items:center;justify-content:center;}
.book-cover .bt{font-family:var(--font-read);font-size:22px;line-height:1.18;font-weight:500;}
.book-meta{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:8px;}

/* hero on library */
.lib-hero{border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;background:var(--ink-deep);color:#fff;}
.lib-hero .copy{padding:36px 40px;flex:1;display:flex;flex-direction:column;justify-content:center;gap:14px;}
.lib-hero .art{width:38%;flex:none;position:relative;background:
   radial-gradient(80% 120% at 80% 0%,oklch(0.30 0.04 84) 0%,transparent 55%),var(--ink);
   border-left:1px solid oklch(0.32 0.02 80 / .6);display:flex;align-items:center;justify-content:center;}

/* ============================================================
   TUNNEL DE VENTE / PAIEMENT
   ============================================================ */
.checkout-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start;}
.tier-card{border:1px solid var(--border);border-radius:14px;padding:24px;cursor:pointer;transition:border-color .15s,box-shadow .15s;position:relative;}
.tier-card:hover{border-color:oklch(0.80 0 0);}
.tier-card.sel{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary);}
.tier-card.sel.gold{border-color:var(--gold-deep);box-shadow:0 0 0 1px var(--gold-deep);}
.tier-price{font-size:32px;font-weight:600;letter-spacing:-0.02em;font-variant-numeric:tabular-nums;}
.pay-method{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--border);border-radius:11px;cursor:pointer;transition:.15s;}
.pay-method:hover{background:var(--muted);}
.pay-method.sel{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary);}
.pay-logo{width:42px;height:42px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:13px;letter-spacing:-0.02em;}
.feat{display:flex;gap:10px;align-items:flex-start;font-size:14px;padding:6px 0;}
.feat .ic{color:var(--primary);flex:none;margin-top:1px;}
.feat.muted-feat .ic{color:var(--muted-foreground);}

/* one-click */
.oneclick{border:1px dashed var(--gold-line);background:var(--gold-soft);border-radius:12px;padding:14px 16px;}

/* ============================================================
   QR IMPÉRIAL
   ============================================================ */
.qr-wrap{display:flex;gap:32px;align-items:center;flex-wrap:wrap;}
.qr-frame{width:260px;height:260px;flex:none;background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:18px;position:relative;box-shadow:var(--shadow-sm);}
.qr-frame .corner-mark{position:absolute;width:22px;height:22px;border:2px solid var(--gold-deep);}
.qr-canvas{width:100%;height:100%;display:grid;}
.qr-key{font-family:var(--font-mono);font-size:22px;letter-spacing:.16em;font-weight:500;}

/* ============================================================
   PYRAMIDE DES BÂTISSEURS
   ============================================================ */
.pyramid{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 0;}
.pyr-tier{position:relative;color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;
  border-radius:8px;transition:transform .18s,box-shadow .18s;cursor:default;}
.pyr-tier:hover{transform:scale(1.015);box-shadow:var(--shadow-md);}
.pyr-cap{background:linear-gradient(160deg,var(--gold),var(--gold-deep));width:150px;height:96px;
  clip-path:polygon(50% 0,100% 100%,0 100%);border-radius:0;}
.pyr-souverain{background:linear-gradient(160deg,var(--ink),oklch(0.26 0.02 80));width:420px;height:108px;border:1px solid var(--gold-line);}
.pyr-eveil{background:linear-gradient(160deg,oklch(0.34 0.05 158),oklch(0.24 0.03 158));width:620px;height:118px;}
.pyr-tier .lbl{font-family:var(--font-read);font-size:21px;font-weight:500;letter-spacing:.02em;}
.pyr-tier .cnt{font-size:12px;opacity:.8;font-family:var(--font-mono);margin-top:3px;}
.pyr-tier.you::after{content:"VOUS";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;background:rgba(255,255,255,.16);
  padding:4px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.25);}

/* ============================================================
   MESSAGERIE CHIFFRÉE
   ============================================================ */
.msg-layout{display:grid;grid-template-columns:300px 1fr;height:calc(100% - 0px);border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--card);}
.msg-list{border-right:1px solid var(--border);overflow-y:auto;}
.msg-conv{display:flex;gap:11px;padding:13px 14px;cursor:pointer;border-bottom:1px solid var(--border);}
.msg-conv:hover{background:var(--muted);}
.msg-conv.active{background:var(--accent);}
.msg-thread{display:flex;flex-direction:column;min-height:0;}
.msg-scroll{flex:1;overflow-y:auto;padding:22px 24px;display:flex;flex-direction:column;gap:14px;background:oklch(0.99 0.002 80);}
.bubble{max-width:64%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;}
.bubble.in{background:var(--muted);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start;}
.bubble.out{background:var(--primary);color:var(--primary-foreground);border-bottom-right-radius:4px;align-self:flex-end;}
.bubble .ts{font-size:10.5px;opacity:.7;margin-top:5px;font-family:var(--font-mono);}
.msg-compose{border-top:1px solid var(--border);padding:14px 16px;display:flex;gap:10px;align-items:center;background:var(--background);}
.msg-compose input{flex:1;height:40px;padding:0 14px;border:1px solid var(--input);border-radius:10px;font-family:inherit;font-size:14px;background:var(--background);color:var(--foreground);}
.msg-compose input:focus-visible{outline:none;border-color:var(--ring);box-shadow:0 0 0 3px color-mix(in oklch,var(--ring) 50%,transparent);}
.enc-banner{display:flex;align-items:center;gap:8px;justify-content:center;font-size:11.5px;color:var(--muted-foreground);
  padding:8px;background:var(--muted);border-bottom:1px solid var(--border);}

/* ============================================================
   ADMIN — monitoring
   ============================================================ */
.fraud-row .dot{width:8px;height:8px;border-radius:50%;flex:none;}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 0 oklch(0.62 0.15 152 / .5);animation:pulse 1.8s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 oklch(0.62 0.15 152 / .5)}70%{box-shadow:0 0 0 8px oklch(0.62 0.15 152 / 0)}100%{box-shadow:0 0 0 0 oklch(0.62 0.15 152 / 0)}}
.bars{display:flex;align-items:flex-end;gap:6px;height:120px;}
.bar{flex:1;background:var(--primary);border-radius:4px 4px 0 0;min-height:4px;transition:height .3s;}
.bar.alt{background:var(--gold);}

/* misc */
.divide-top{border-top:1px solid var(--border);}
.icon-tile{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex:none;}
.tile-muted{background:var(--muted);color:var(--foreground);}
.lock-veil{position:absolute;inset:0;background:color-mix(in oklch,var(--ink-deep) 72%,transparent);backdrop-filter:blur(2px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;border-radius:14px;z-index:3;color:#fff;text-align:center;padding:24px;}

::selection{background:oklch(0.74 0.12 84 / .25);}
