/* ============================================================
   DUMP — Espace testeurs · style Warm Lamp
   Parti pris : fond charcoal profond, la couleur émerge comme
   la lumière d'une lampe chaude dans le noir. Pas de cream-serif
   générique : le noir porte la chaleur.
   ============================================================ */

:root{
  --charcoal:#1A1815;
  --charcoal-2:#221F1B;
  --amber:#E8A44A;
  --terracotta:#E07A5F;
  --lavender:#B4A0C8;
  --sand:#F2CC8F;
  --cream:#F5F0E8;
  --fire:#E8542E;

  --ink:#F5F0E8;
  --ink-soft:rgba(245,240,232,.66);
  --ink-faint:rgba(245,240,232,.40);
  --line:rgba(245,240,232,.12);

  --display:"Fraunces",Georgia,serif;
  --body:"Inter",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;

  --maxw:1080px;
  --focus:var(--sand);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--charcoal);
  color:var(--ink);
  font-family:var(--body);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.wrap.narrow{max-width:680px}
em{font-style:normal;color:var(--ink-faint)}
em.hl{color:var(--amber);font-style:italic}

/* Accessibilité : skip link + texte caché */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{
  position:absolute;left:-999px;top:8px;z-index:50;
  background:var(--amber);color:var(--charcoal);font-weight:600;
  padding:10px 18px;border-radius:999px;text-decoration:none;
}
.skip:focus{left:12px}

/* Focus clavier visible et homogène partout */
a:focus-visible,button:focus-visible,
textarea:focus-visible,select:focus-visible,input:focus-visible{
  outline:2px solid var(--focus);outline-offset:2px;
}

/* ---------- Ambient orb (signature) ---------- */
.ambient{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{
  position:absolute;top:-18vh;left:50%;width:75vh;height:75vh;
  transform:translateX(-50%);
  background:radial-gradient(circle at 50% 40%,
    rgba(232,164,74,.34), rgba(224,122,95,.16) 38%, rgba(26,24,21,0) 68%);
  filter:blur(8px);
  animation:breathe 11s ease-in-out infinite;
}
.mote{position:absolute;border-radius:50%;filter:blur(2px);opacity:.5}
.m1{width:10px;height:10px;background:var(--sand);left:18%;top:42%;animation:rise 14s linear infinite}
.m2{width:7px;height:7px;background:var(--lavender);left:74%;top:60%;animation:rise 19s linear infinite 3s}
.m3{width:6px;height:6px;background:var(--terracotta);left:52%;top:72%;animation:rise 16s linear infinite 6s}
@keyframes breathe{0%,100%{transform:translateX(-50%) scale(1);opacity:.9}50%{transform:translateX(-50%) scale(1.07);opacity:1}}
@keyframes rise{0%{transform:translateY(20px);opacity:0}12%{opacity:.6}88%{opacity:.5}100%{transform:translateY(-60vh);opacity:0}}

/* ---------- Layout sections ---------- */
.hero,.section{position:relative;z-index:1}
.section{padding:84px 0}
.kicker{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--amber);margin-bottom:18px;
}

/* ---------- Hero ---------- */
.hero{padding:120px 0 72px;text-align:left}
.eyebrow{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-faint);margin-bottom:26px;
}
.display{
  font-family:var(--display);font-weight:500;
  font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.04;
  letter-spacing:-.02em;margin-bottom:26px;text-wrap:balance;
}
.lit{
  color:var(--sand);
  text-shadow:0 0 36px rgba(242,204,143,.45);
  font-style:italic;
}
.lede{
  font-size:clamp(1.05rem,1.7vw,1.28rem);
  color:var(--ink-soft);max-width:620px;margin-bottom:38px;text-wrap:pretty;
}

/* ---------- CTA ---------- */
.cta{
  display:inline-block;background:var(--amber);color:var(--charcoal);
  font-weight:600;font-size:1rem;padding:15px 30px;border-radius:999px;
  text-decoration:none;border:none;cursor:pointer;font-family:var(--body);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  box-shadow:0 8px 30px rgba(232,164,74,.28);
}
.cta:hover{transform:translateY(-2px);box-shadow:0 12px 38px rgba(232,164,74,.4)}
.cta:active{transform:translateY(0)}
.cta:disabled{opacity:.6;cursor:default;transform:none;box-shadow:none}

/* ---------- Doctrine ---------- */
.creeds{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.creed{
  background:var(--charcoal-2);border:1px solid var(--line);
  border-radius:18px;padding:28px;
  transition:border-color .2s ease,transform .2s ease;
}
.creed:hover{border-color:rgba(232,164,74,.4);transform:translateY(-3px)}
.creed h3{
  font-family:var(--display);font-weight:500;font-size:1.32rem;
  margin-bottom:12px;color:var(--cream);
}
.creed p{color:var(--ink-soft);font-size:.98rem}

/* ---------- Watchlist ---------- */
.watch .wrap{max-width:760px}
.watchlist{list-style:none;display:flex;flex-direction:column;gap:2px;margin-top:6px}
.watchlist li{
  padding:20px 0;border-bottom:1px solid var(--line);
  color:var(--ink-soft);font-size:1.02rem;
}
.watchlist li:last-child{border-bottom:none}
.wl-tag{
  display:inline-block;font-family:var(--mono);font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--lavender);
  border:1px solid rgba(180,160,200,.35);border-radius:6px;
  padding:3px 9px;margin-right:14px;
}

/* ---------- Feedback ---------- */
.feedback{padding-bottom:110px}
.feedback#retour{scroll-margin-top:24px}
.h2{font-family:var(--display);font-weight:500;font-size:clamp(1.8rem,3.5vw,2.5rem);letter-spacing:-.01em;margin-bottom:14px}
.sub{color:var(--ink-soft);margin-bottom:34px;font-size:1.05rem}

.card{
  background:var(--charcoal-2);border:1px solid var(--line);
  border-radius:22px;padding:30px;
  box-shadow:0 24px 60px rgba(0,0,0,.35);
}

/* type selector */
.types-fs{border:none}
.types{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.type{
  display:flex;flex-direction:column;align-items:center;gap:7px;
  background:transparent;border:1px solid var(--line);border-radius:14px;
  padding:14px 6px;color:var(--ink-soft);cursor:pointer;font-size:.86rem;
  font-weight:500;font-family:var(--body);min-height:74px;
  transition:transform .16s ease,border-color .16s ease,background .16s ease,color .16s ease;
}
.type .ic{font-size:1.4rem;line-height:1}
.type:hover{border-color:rgba(245,240,232,.3);color:var(--ink)}
.type:active{transform:scale(.96)}
.type.active{
  border-color:var(--amber);background:rgba(232,164,74,.1);color:var(--cream);
  box-shadow:0 0 0 1px var(--amber) inset, 0 0 24px rgba(232,164,74,.18);
}

.lbl{display:block;font-size:.82rem;color:var(--ink-faint);font-weight:500;margin-bottom:8px}

textarea,select,input[type=text]{
  width:100%;background:var(--charcoal);color:var(--ink);
  border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;font-family:var(--body);font-size:1rem;
  transition:border-color .16s ease;
}
textarea{resize:vertical;min-height:108px}
textarea:focus,select:focus,input:focus{border-color:var(--amber)}

.counter{font-family:var(--mono);font-size:.74rem;color:var(--ink-faint);min-height:1.1em;margin:6px 2px 12px;text-align:right}

.meta-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:22px}
.field{display:flex;flex-direction:column;gap:7px}
.field>span{font-size:.82rem;color:var(--ink-faint);font-weight:500}

.send{width:100%;text-align:center}
.hint-key{margin-top:12px;text-align:center;font-size:.76rem;color:var(--ink-faint)}
.hint-key kbd{font-family:var(--mono);background:var(--charcoal);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-size:.72rem}
.formnote{margin-top:12px;font-size:.9rem;min-height:1.2em;text-align:center;color:var(--sand)}
.formnote.err{color:var(--terracotta)}

/* thanks state */
.card.thanks{text-align:center;padding:48px 30px}
.check{
  width:62px;height:62px;border-radius:50%;margin:0 auto 20px;
  display:grid;place-items:center;font-size:1.8rem;color:var(--charcoal);
  background:var(--amber);box-shadow:0 0 40px rgba(232,164,74,.45);
  animation:pop .4s cubic-bezier(.2,1.3,.4,1) both;
}
@keyframes pop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.card.thanks h3{font-family:var(--display);font-weight:500;font-size:1.6rem;margin-bottom:10px;color:var(--cream)}
.card.thanks p{color:var(--ink-soft);max-width:400px;margin:0 auto 24px}

/* ---------- Footer ---------- */
.foot{position:relative;z-index:1;border-top:1px solid var(--line);padding:34px 0;text-align:center}
.foot p{color:var(--ink-faint);font-size:.88rem;font-family:var(--mono);letter-spacing:.04em}

/* ---------- Responsive ---------- */
@media(max-width:820px){
  .creeds{grid-template-columns:1fr;gap:14px}
}
@media(max-width:560px){
  .section{padding:60px 0}
  .hero{padding:88px 0 56px}
  .wrap{padding:0 20px}
  .types{grid-template-columns:repeat(2,1fr)}
  .meta-row{grid-template-columns:1fr}
  .card{padding:22px}
  .cta{display:block;text-align:center}
  .hero .cta{display:inline-block}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .orb,.mote,.check{animation:none}
  *{transition:none!important}
}
