:root{
  --ink:        #141229;   /* nuit d'encre */
  --ink-soft:   #211d3d;
  --paper:      #f7f3ea;   /* page */
  --paper-dim:  #e9e2d3;
  --lamp:       #f0a830;   /* lampe de lecture, accent chaud */
  --lamp-deep:  #d98324;
  --rose:       #c97b84;   /* ruban secondaire */
  --text-dim:   #9a96b0;
  --ok:         #5fb98f;
  --err:        #e0697a;
  --radius:     14px;
  --shadow:     0 18px 50px -20px rgba(0,0,0,.55);
}

*{box-sizing:border-box;margin:0;padding:0}

body{
  font-family:'Inter',system-ui,sans-serif;
  background:
    radial-gradient(1200px 600px at 50% -10%, #2a2550 0%, transparent 60%),
    var(--ink);
  color:var(--paper);
  min-height:100vh;
  line-height:1.55;
}

/* ---- En-tête ---- */
.masthead{
  text-align:center;
  padding:64px 20px 40px;
  position:relative;
}
.lamp{
  width:120px;height:120px;margin:0 auto 8px;
  border-radius:50%;
  background:radial-gradient(circle at 50% 40%, var(--lamp) 0%, var(--lamp-deep) 35%, transparent 70%);
  filter:blur(6px);
  opacity:.85;
}
.masthead h1{
  font-family:'Fraunces',serif;
  font-weight:600;
  font-size:clamp(2.6rem,7vw,4.2rem);
  letter-spacing:-.02em;
  margin-top:-48px;
  text-shadow:0 2px 30px rgba(240,168,48,.25);
}
.tagline{
  max-width:30ch;margin:14px auto 0;
  color:var(--text-dim);
  font-size:1.02rem;
}

/* ---- Mise en page ---- */
.wrap{
  max-width:560px;margin:0 auto;
  padding:0 20px 60px;
  display:flex;flex-direction:column;gap:24px;
}

.card{
  background:var(--paper);
  color:var(--ink);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
}

.step-label{
  display:inline-block;
  font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--lamp-deep);
  background:rgba(240,168,48,.14);
  padding:4px 10px;border-radius:20px;
  margin-bottom:10px;
}
.card h2{
  font-family:'Fraunces',serif;font-weight:600;
  font-size:1.5rem;margin-bottom:18px;
}

/* ---- Champs ---- */
.field{display:block;margin-bottom:20px}
.field span{
  display:block;font-size:.85rem;font-weight:500;
  color:#5a5670;margin-bottom:6px;
}
.field input{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--paper-dim);border-radius:10px;
  background:#fff;font-size:1rem;font-family:inherit;color:var(--ink);
  transition:border-color .15s;
}
.field input:focus{outline:none;border-color:var(--lamp)}

/* ---- Sélecteur de mode ---- */
.modes{
  display:flex;gap:8px;
  background:var(--paper-dim);
  padding:5px;border-radius:12px;margin-bottom:20px;
}
.mode-btn{
  flex:1;padding:11px;border:none;border-radius:8px;
  background:transparent;font:inherit;font-weight:500;
  color:#5a5670;cursor:pointer;transition:.15s;
}
.mode-btn.active{background:#fff;color:var(--ink);box-shadow:0 2px 8px rgba(0,0,0,.08)}

.mode-panel{margin-bottom:20px}

/* ---- Enregistreur ---- */
.recorder{
  display:flex;align-items:center;gap:18px;
  justify-content:center;padding:18px 0;
}
.rec-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border:none;border-radius:40px;
  background:var(--ink);color:var(--paper);
  font:inherit;font-weight:600;cursor:pointer;transition:.2s;
}
.rec-btn:hover{transform:translateY(-1px)}
.rec-btn.recording{background:var(--err)}
.rec-dot{
  width:11px;height:11px;border-radius:50%;
  background:var(--err);transition:.2s;
}
.rec-btn.recording .rec-dot{
  background:#fff;animation:pulse 1s infinite;
}
@keyframes pulse{50%{opacity:.3}}
.timer{
  font-family:'Fraunces',serif;font-size:1.6rem;font-variant-numeric:tabular-nums;
  color:var(--ink);min-width:80px;
}
#preview{width:100%;margin-top:14px}

/* ---- Dropzone ---- */
.dropzone{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:34px 20px;border:2px dashed var(--paper-dim);border-radius:12px;
  cursor:pointer;transition:.15s;text-align:center;
}
.dropzone:hover{border-color:var(--lamp);background:rgba(240,168,48,.05)}
.dz-icon{font-size:2rem;color:var(--lamp-deep);line-height:1}
.dz-text{font-weight:500;color:#5a5670}
.dz-name{font-size:.85rem;color:var(--lamp-deep);font-weight:600}

/* ---- Boutons ---- */
.primary{
  width:100%;padding:15px;border:none;border-radius:10px;
  background:var(--lamp);color:var(--ink);
  font:inherit;font-weight:600;font-size:1.02rem;cursor:pointer;transition:.2s;
}
.primary:hover:not(:disabled){background:var(--lamp-deep);color:var(--paper)}
.primary:disabled{opacity:.4;cursor:not-allowed}
.ghost{
  width:100%;padding:13px;border:1.5px solid var(--paper-dim);border-radius:10px;
  background:transparent;font:inherit;font-weight:500;color:#5a5670;cursor:pointer;transition:.15s;
}
.ghost:hover{border-color:var(--ink);color:var(--ink)}

.status{margin-top:14px;font-size:.9rem;text-align:center;min-height:1.2em}
.status.err{color:var(--err)}
.status.ok{color:var(--ok)}
.status.load{color:#5a5670}

/* ---- Résultat : marque-page ---- */
.bookmark{
  width:240px;margin:0 auto 24px;
  background:#fff;border-radius:10px;
  padding:26px 22px 20px;text-align:center;
  box-shadow:0 10px 30px -12px rgba(0,0,0,.3);
  border-top:6px solid var(--lamp);
  position:relative;
}
.bookmark-hole{
  width:14px;height:14px;border-radius:50%;
  background:var(--ink);position:absolute;top:18px;left:50%;transform:translateX(-50%);
  opacity:0;  /* décoratif, masqué par défaut pour rester sobre */
}
.bookmark img{width:100%;height:auto;display:block;border-radius:4px}
.bookmark-title{
  font-family:'Fraunces',serif;font-weight:600;font-size:1.05rem;
  margin-top:14px;color:var(--ink);line-height:1.3;
}
.bookmark-hint{font-size:.78rem;color:var(--text-dim);margin-top:4px;letter-spacing:.04em}
.result-actions{display:flex;flex-direction:column;gap:10px}

/* ---- Bibliothèque ---- */
.lib-list{list-style:none;display:flex;flex-direction:column;gap:10px}
.lib-list li{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:12px 14px;background:var(--paper-dim);border-radius:10px;
}
.lib-title{flex:1 1 100%;font-weight:500;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lib-actions{display:flex;gap:4px;flex:1;justify-content:flex-end}
.lib-link,.lib-qr,.lib-del{
  border:none;background:none;cursor:pointer;font:inherit;font-size:.85rem;
  padding:6px 10px;border-radius:7px;font-weight:500;
}
.lib-link{color:var(--lamp-deep)}
.lib-link:hover{background:rgba(240,168,48,.15)}
.lib-qr{color:var(--ink)}
.lib-qr:hover{background:var(--paper)}
.lib-del{color:var(--err)}
.lib-del:hover{background:rgba(224,105,122,.12)}
.lib-empty{color:var(--text-dim);font-size:.9rem;text-align:center;padding:8px}

.foot{
  text-align:center;color:var(--text-dim);font-size:.82rem;
  padding:30px 20px 50px;
}

/* ---- Impression : seul le marque-page sort ---- */
@media print{
  body{background:#fff}
  .masthead,.maker,.library,.foot,.result-actions,.step-label,.result h2{display:none!important}
  .wrap{max-width:none;padding:0}
  .result{box-shadow:none;padding:0}
  .bookmark{box-shadow:none;border:1px solid #ccc;margin:40px auto}
}

@media(max-width:480px){
  .masthead{padding:44px 20px 30px}
  .card{padding:22px}
}
