/* ============================================================
   PARCOURS · Shared shell
   Masthead, rubrique navigation, cards, buttons, ornaments.
   ============================================================ */
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}
html{-webkit-text-size-adjust:100%}

body{
  font-family:var(--sans);
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(200,155,74,.18), transparent 60%),
    radial-gradient(900px 500px at 110% 10%, rgba(139,35,49,.10), transparent 60%),
    var(--cream);
  background-attachment:fixed;
  color:var(--ink);
  line-height:1.5;
  padding:calc(28px + var(--safe-top)) 20px calc(60px + var(--safe-bottom));
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

.shell{max-width:var(--shell-max);margin:0 auto}

/* hidden helper + view fade */
[hidden]{display:none !important}
body.modal-open{overflow:hidden}     /* lock background scroll while a modal is open */
/* No `both`/forwards fill: a filling `transform:none` keyframe computes to an
   identity matrix, which would make #view a containing block and break every
   position:fixed overlay rendered inside a view (the add-word modal, the
   keep-a-word sheet). The reflow-restart in mount() keeps the entrance clean. */
.view-fade{animation:fadeIn .28s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ─── MASTHEAD ─────────────────────────── */
.masthead{
  position:relative;
  border-bottom:3px double var(--ink);
  padding-bottom:14px;
  margin-bottom:8px;
}
.masthead-row{
  display:flex;align-items:baseline;justify-content:space-between;
  gap:20px;flex-wrap:wrap;
}
.masthead-left{display:flex;flex-direction:column}
.brand{
  font-family:var(--blackletter);
  font-weight:400;
  font-size:clamp(2.4rem,6.5vw,4.6rem);
  line-height:.95;letter-spacing:0;color:var(--burgundy);
  text-decoration:none;
}
.brand .accent{color:var(--burgundy-deep)}
.tag{
  font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--ink-soft);opacity:.75;
  margin-top:6px;
}
.date{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--ink-soft);opacity:.75;text-align:right;
}
.tagline{
  text-align:center;font-family:var(--serif-lit);font-style:italic;
  font-size:1.05rem;color:var(--burgundy);opacity:.85;margin:10px 0 8px;letter-spacing:.02em;
}
.masthead-meta{
  text-align:center;font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-soft);opacity:.7;
  padding-top:10px;border-top:1px solid var(--line);user-select:none;
}

/* ─── RUBRIQUE NAV (top · desktop/tablet) ─── */
.rubriques{
  display:flex;align-items:stretch;justify-content:center;gap:0;
  margin:14px 0 30px;border-bottom:1px solid var(--line);
}
.rub{
  appearance:none;background:none;border:none;cursor:pointer;
  font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);opacity:.7;padding:12px 26px 14px;
  text-decoration:none;display:inline-flex;flex-direction:column;align-items:center;gap:3px;
  border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s;
}
.rub .rub-fr{font-family:var(--serif-lit);font-style:italic;font-size:1.15rem;letter-spacing:0;text-transform:none;color:var(--ink)}
.rub:hover{opacity:1;color:var(--burgundy)}
.rub.active{opacity:1;border-bottom-color:var(--burgundy)}
.rub.active .rub-fr{color:var(--burgundy)}

/* ─── BOTTOM TAB BAR (phone · PWA) ─────── */
.tabbar{
  display:none;
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  background:rgba(251,247,239,.92);
  backdrop-filter:saturate(1.4) blur(12px);
  -webkit-backdrop-filter:saturate(1.4) blur(12px);
  border-top:1px solid var(--line);
  padding-bottom:var(--safe-bottom);
}
.tabbar-inner{display:flex;height:var(--tabbar-h)}
.tab{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  text-decoration:none;color:var(--ink-soft);opacity:.65;
  font-family:var(--mono);font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;
  transition:.15s;border:none;background:none;cursor:pointer;
}
.tab svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.6}
.tab.active{opacity:1;color:var(--burgundy)}

/* ─── SECTION LABELS ───────────────────── */
.section-label{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--ink-soft);opacity:.7;margin:8px 0 14px;display:flex;align-items:center;gap:12px;
}
.section-label .lbl-orn{color:var(--burgundy);opacity:.6}
.section-label::after{content:'';flex:1;height:1px;background:var(--line)}

.fleuron{
  text-align:center;font-family:var(--serif-lit);color:var(--burgundy);opacity:.55;
  font-size:1.4rem;margin:22px 0 14px;letter-spacing:.4em;user-select:none;
}
.footnote{
  text-align:center;color:var(--ink-soft);opacity:.6;font-size:.78rem;
  margin-top:26px;font-style:italic;
}

/* ─── GENERIC CARD ─────────────────────── */
.card{
  position:relative;display:block;width:100%;text-align:left;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;cursor:pointer;color:inherit;font-family:inherit;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  overflow:hidden;text-decoration:none;
}
.card::after{ /* top family stripe */
  content:'';position:absolute;top:0;left:0;right:0;height:5px;
  background:var(--stripe,transparent);z-index:2;
}
.card::before{ /* corner wash */
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg, var(--wash,transparent) 0%, transparent 70%);
  opacity:.5;pointer-events:none;
}
.card:hover{transform:translateY(-3px);box-shadow:0 18px 40px -20px rgba(26,31,46,.35);border-color:var(--line-strong)}
.card>*{position:relative;z-index:1}

/* ─── BADGES / KICKERS ─────────────────── */
.kicker{
  font-family:var(--mono);font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);opacity:.72;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap;
}
.lvl-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.12em;
  color:#fff;background:var(--lvl,var(--burgundy));
  padding:3px 8px;border-radius:6px;line-height:1;
}
.lvl-dot{width:8px;height:8px;border-radius:50%;background:var(--lvl,var(--burgundy));display:inline-block;flex-shrink:0}

/* ─── BUTTONS ──────────────────────────── */
.btn-primary{
  background:var(--ink);color:var(--cream);border:none;border-radius:var(--radius-sm);
  padding:15px 22px;font-size:.95rem;font-weight:600;letter-spacing:.05em;cursor:pointer;
  font-family:inherit;transition:.2s;display:inline-flex;align-items:center;justify-content:center;gap:10px;
}
.btn-primary:hover{background:var(--burgundy)}
.btn-primary:disabled{background:#c4bdab;color:#f1ede3;cursor:not-allowed;opacity:.7}
.btn-ghost{
  background:transparent;border:1.5px solid var(--line);color:var(--ink-soft);
  border-radius:var(--radius-sm);padding:13px 20px;font-size:.92rem;font-weight:600;letter-spacing:.04em;
  cursor:pointer;font-family:inherit;transition:.2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none;
}
.btn-ghost:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-small{padding:8px 14px;font-size:.8rem;border-radius:999px}

/* pill row (filters) */
.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 8px}
.pill{
  appearance:none;cursor:pointer;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft);background:var(--paper);
  border:1px solid var(--line);border-radius:999px;padding:7px 14px;transition:.18s;
  display:inline-flex;align-items:center;gap:7px;
}
.pill:hover{border-color:var(--line-strong)}
.pill.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.pill.active .lvl-dot{box-shadow:0 0 0 2px rgba(255,255,255,.5)}

/* ─── QUIET CONFIRMATION (toast) ───────── */
.toast{
  position:fixed;left:50%;bottom:calc(28px + var(--safe-bottom));transform:translateX(-50%) translateY(12px);
  background:var(--ink);color:var(--cream);font-family:var(--serif-lit);font-style:italic;font-size:1.02rem;
  padding:12px 22px;border-radius:999px;box-shadow:0 14px 40px -16px rgba(26,31,46,.6);
  opacity:0;pointer-events:none;transition:.32s cubic-bezier(.2,.7,.3,1);z-index:200;white-space:nowrap;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ─── EMPTY STATE ──────────────────────── */
.empty{
  text-align:center;padding:54px 20px;color:var(--ink-soft);
}
.empty .empty-orn{font-family:var(--serif-lit);font-size:2.4rem;color:var(--burgundy);opacity:.4}
.empty h3{font-family:var(--serif-lit);font-style:italic;font-weight:600;font-size:1.5rem;margin:8px 0 6px;color:var(--ink)}
.empty p{max-width:34rem;margin:0 auto;font-size:.96rem;opacity:.85}

/* ─── PAGE HEAD (within a view) ────────── */
.page-head{margin:6px 0 18px}
.page-title{
  font-family:var(--serif-display);font-weight:700;font-style:italic;font-size:clamp(1.9rem,4.6vw,3rem);
  line-height:1.04;letter-spacing:-.5px;margin:0 0 8px;color:var(--ink);
}
.page-title em{font-style:italic;color:inherit}
.page-dek{font-family:var(--serif-lit);font-size:1.12rem;line-height:1.5;color:var(--ink-soft);max-width:46rem;margin:0}

/* ─── DESK (home) ──────────────────────── */
.desk{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.desk-resume{padding:24px 24px 22px}
.desk-resume-title{
  font-family:var(--serif-display);font-weight:700;font-size:clamp(1.5rem,3.6vw,2.2rem);
  line-height:1.08;letter-spacing:-.3px;margin:10px 0 6px;color:var(--ink);
}
.desk-resume-dek{font-family:var(--serif-lit);font-size:1.08rem;line-height:1.45;color:var(--ink-soft);opacity:.9;max-width:46rem}
.desk-resume--empty .desk-resume-title{font-style:italic;color:var(--burgundy)}

.desk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.desk-stat{display:flex;flex-direction:column;justify-content:flex-end;min-height:118px;padding:20px}
.desk-num{font-family:var(--serif-lit);font-weight:600;font-size:3rem;line-height:.9;color:var(--ink)}
.desk-stat-label{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);opacity:.72;margin-top:8px}

.desk-sync{padding:22px 24px;cursor:default}
.desk-sync:hover{transform:none;box-shadow:none;border-color:var(--line)}
.desk-sync-note{font-size:.92rem;line-height:1.5;color:var(--ink-soft);max-width:48rem;margin:10px 0 14px}
.desk-code-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.desk-code{
  font-family:var(--mono);font-size:1.05rem;letter-spacing:.14em;color:var(--burgundy);
  background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:9px 16px;user-select:all;
}
.desk-link{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.desk-link summary{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);cursor:pointer;opacity:.8}
.desk-link summary:hover{color:var(--burgundy)}
.desk-link-form{display:flex;gap:8px;margin:12px 0 6px;flex-wrap:wrap}
.desk-link-form input{
  flex:1;min-width:180px;font-family:var(--mono);font-size:.9rem;letter-spacing:.08em;
  border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;background:var(--cream);color:var(--ink);text-transform:uppercase;
}
.desk-link-form input:focus{outline:none;border-color:var(--burgundy);background:#fff}
.desk-link-warn{font-size:.78rem;color:var(--ink-soft);opacity:.7;font-style:italic;margin:2px 0 0}

/* ─── RESPONSIVE ───────────────────────── */
@media(max-width:760px){
  body{padding:calc(18px + var(--safe-top)) 14px calc(40px + var(--safe-bottom))}
  .masthead-row{align-items:flex-start}
  .rubriques{margin:12px 0 22px}
}

/* Phone ≤540px — digital news-app look: drop ornaments, flat paper, bottom tabs */
@media(max-width:540px){
  body{
    background:var(--paper);   /* flat paper, no decorative blobs */
    padding:12px 14px calc(var(--tabbar-h) + 24px + var(--safe-bottom));
  }
  .shell{max-width:100%}
  /* Phone PWA: pin the masthead so the header never scrolls away (the bottom
     tabbar/footer is fixed too). The masthead owns --safe-top here, since the
     body padding-top dropped it above. */
  .masthead{
    position:sticky;top:0;z-index:60;
    border-bottom:1px solid var(--line);
    padding-top:var(--safe-top);padding-bottom:10px;margin-bottom:14px;
    background:rgba(251,247,239,.92);                /* --paper, translucent */
    backdrop-filter:saturate(1.4) blur(12px);
    -webkit-backdrop-filter:saturate(1.4) blur(12px);
  }
  .masthead-row{align-items:center;justify-content:space-between}
  .brand{font-family:var(--serif-display);font-weight:800;font-size:1.85rem;letter-spacing:-.5px}
  .tag{display:none}
  .date{font-size:.62rem;letter-spacing:.1em}
  .tagline,.masthead-meta,.fleuron,.footnote{display:none}
  .rubriques{display:none}            /* top nav hidden … */
  .tabbar{display:block}              /* … bottom tab bar appears */
  .section-label{font-size:.6rem;letter-spacing:.18em;margin:6px 0 10px}
  .page-dek{font-family:var(--sans);font-size:.95rem;color:var(--ink-soft)}
  .desk-grid{gap:10px}
  .desk-num{font-size:2.1rem}
  .desk-stat{min-height:96px;padding:16px}
  .desk-stat-label{font-size:.54rem}
}
