/* Inoraline — App design éditorial sombre (cohérent avec landing) */
:root{
  --ivory:#F3EDE3; --ivory-soft:#EDE5D7; --ivory-deep:#E6DCC8;
  --ink:#1F1420; --ink-soft:#2C1F2E;
  --ink-60:rgba(31,20,32,.6); --ink-40:rgba(31,20,32,.4); --ink-15:rgba(31,20,32,.15); --ink-08:rgba(31,20,32,.08);
  --sage:oklch(0.52 0.08 155); --sage-dark:oklch(0.38 0.07 155);
  --ocre:oklch(0.72 0.12 75); --ocre-deep:oklch(0.58 0.13 65); --ocre-soft:oklch(0.93 0.05 80);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Instrument Sans",ui-sans-serif,system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0; background:var(--ivory); color:var(--ink); font-family:var(--sans); font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased}
button{font:inherit; color:inherit; cursor:pointer; background:0; border:0; padding:0}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
em{font-style:italic}

/* ── Mark / logo ───────────────────────────────────────────── */
.mark{display:inline-flex; align-items:baseline; gap:5px; font-size:20px; line-height:1}
.mark .dot{width:7px; height:7px; border-radius:50%; background:var(--ocre); align-self:center; margin-right:3px}
.mark .inora{font-family:var(--serif); font-style:italic}
.mark .line{font-family:var(--sans); font-weight:700; letter-spacing:-.02em; position:relative}
.mark .line::after{content:""; position:absolute; left:-1px; right:-3px; bottom:-2px; height:1.5px; background:var(--ocre)}
.mark.light .inora, .mark.light .line{color:var(--ivory)}

/* ── Top bar SOMBRE (clé du redesign) ──────────────────────── */
.topbar{
  background:var(--ink);
  color:var(--ivory);
  position:sticky; top:0; z-index:20;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.topbar-inner{
  max-width:1200px; margin:0 auto;
  padding:14px clamp(20px, 4vw, 40px);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.topbar nav{display:flex; align-items:center; gap:18px; font-size:13px}
.topbar .premium{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:999px;
  background:rgba(212,150,90,.12); border:1px solid rgba(212,150,90,.4);
  color:var(--ocre); font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
}
.topbar .premium::before{content:"✦"; font-size:11px}
.topbar .who{
  font-family:var(--serif); font-style:italic; font-size:14px;
  color:rgba(243,237,227,.85);
  padding-left:18px; border-left:1px solid rgba(255,255,255,.1);
}
.topbar .lang{
  font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase;
  padding:4px 10px; border:1px solid rgba(255,255,255,.15); border-radius:999px;
  color:rgba(243,237,227,.7);
}
.topbar .ghost{ color:rgba(243,237,227,.6); display:inline-flex; align-items:center; gap:6px; font-size:13px; cursor:pointer }
.topbar .ghost:hover{ color:var(--ivory) }
.topbar .ghost .ic{ font-size:13px; opacity:.8 }
.topbar .sep{ width:1px; height:14px; background:rgba(255,255,255,.1) }

/* ── Page ─────────────────────────────────────────────────── */
.page{ max-width:1200px; margin:0 auto; padding:48px clamp(20px, 4vw, 40px) 120px }
.page.narrow{ max-width:680px }
.page.medium{ max-width:880px }

.eyebrow{font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-60); display:inline-flex; align-items:center; gap:8px}
.eyebrow .dot{width:6px; height:6px; border-radius:50%; background:var(--ocre); display:inline-block}

/* ── Buttons (réutilisables, pas de coins ronds-style produit) ── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:11px 18px; font-size:14px; line-height:1;
  border-radius:8px; cursor:pointer; transition:.15s;
  font-family:var(--sans); font-weight:500;
}
.btn.primary{ background:var(--ocre-deep); color:var(--ivory) }
.btn.primary:hover{ background:var(--ocre); color:var(--ink) }
.btn.ghost{ background:transparent; color:var(--ink); border:1px solid var(--ink-15) }
.btn.ghost:hover{ background:var(--ink); color:var(--ivory); border-color:var(--ink) }
.btn.sm{ padding:8px 14px; font-size:13px }
.btn .ic{ font-size:14px; opacity:.85 }

/* ── 1. LOGIN ──────────────────────────────────────────────── */
.auth{ min-height:calc(100vh - 60px); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:48px 24px; }
.auth .lead{ text-align:center; margin-bottom:40px; max-width:480px }
.auth h1{
  font-family:var(--serif); font-weight:400; font-style:italic;
  font-size:clamp(48px, 6vw, 72px); line-height:1; letter-spacing:-.025em;
  margin:0 0 14px; font-variation-settings:"opsz" 144;
}
.auth h1 em{ background:linear-gradient(92deg,var(--ocre-deep),var(--sage)); -webkit-background-clip:text; background-clip:text; color:transparent }
.auth .sub{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--ink-60); margin:0 }

.auth .form{
  width:100%; max-width:440px;
  border-top:1px solid var(--ink-15); border-bottom:1px solid var(--ink-15);
  padding:32px 0;
  display:flex; flex-direction:column; gap:18px;
}
.field{ display:flex; flex-direction:column; gap:8px }
.field label{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:var(--ink-60); text-transform:uppercase }
.field input{
  width:100%; padding:14px 16px; font:inherit; font-size:15px; color:var(--ink);
  border:1px solid var(--ink-15); border-radius:6px; background:var(--ivory);
}
.field input:focus{ outline:0; border-color:var(--ocre); box-shadow:0 0 0 3px rgba(212,150,90,.15) }
.field input::placeholder{ color:var(--ink-40); font-style:italic; font-family:var(--serif) }
.field input[type="checkbox"]{ width:auto; padding:0; border:none; background:transparent; box-shadow:none; border-radius:0; flex-shrink:0 }

.auth .alt{ margin-top:24px; text-align:center; font-size:13.5px; color:var(--ink-60) }
.auth .alt a{ color:var(--ocre-deep); border-bottom:1px solid currentColor; padding-bottom:1px }
.auth .alt a:hover{ color:var(--ink) }
.auth .legal{ margin-top:40px; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-40) }
.auth .legal a{ color:var(--ink-60); margin:0 6px }
.auth .legal a:hover{ color:var(--ink); border-bottom:1px solid currentColor }

/* ── 2. CHILD PICKER ───────────────────────────────────────── */
.picker-banner{
  display:flex; gap:8px; justify-content:center; margin-bottom:32px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-60);
}
.picker-banner .pill{ display:inline-flex; align-items:center; gap:6px; padding:7px 14px; border:1px solid var(--ink-15); border-radius:999px; background:var(--ivory) }
.picker-banner .pill b{ color:var(--ocre-deep); font-weight:500 }
.picker-banner .pill .ic{ font-size:13px; opacity:.7 }

.picker-head{ text-align:left; margin-bottom:32px }
.picker-head h1{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(40px, 5vw, 56px); line-height:1; letter-spacing:-.02em;
  margin:0 0 10px; font-variation-settings:"opsz" 144;
}
.picker-head h1 em{ font-style:italic; font-weight:300; color:var(--ocre-deep) }
.picker-head .sub{ font-family:var(--serif); font-style:italic; font-size:17px; color:var(--ink-60); margin:0 }

/* Onboarding checklist — sober, no card */
.onboarding{
  border:1px solid var(--ink-15); border-radius:6px;
  padding:20px 24px; margin-bottom:48px; max-width:520px;
  background:linear-gradient(120deg, var(--ocre-soft) 0%, transparent 80%);
}
.onboarding .title{ font-family:var(--serif); font-style:italic; font-size:18px; margin-bottom:12px; display:flex; align-items:center; gap:8px }
.onboarding .title .ic{ color:var(--ocre-deep) }
.onboarding ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:8px }
.onboarding li{ display:flex; align-items:center; gap:10px; font-size:14px; color:var(--ink) }
.onboarding li.done{ color:var(--ink-60) }
.onboarding .check{
  width:18px; height:18px; border-radius:50%; border:1.5px solid var(--ink-15); flex-shrink:0;
  display:grid; place-items:center;
}
.onboarding li.done .check{ background:var(--ocre-deep); border-color:var(--ocre-deep); color:var(--ivory) }
.onboarding li.done .check::after{ content:"✓"; font-size:11px; line-height:1 }

/* Children grid — flat, no shadow card */
.children{
  display:grid; gap:16px;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  max-width:760px;
}
.child-card{
  border:1px solid var(--ink-15); border-radius:6px;
  padding:24px 22px;
  display:flex; flex-direction:column; gap:14px;
  background:var(--ivory);
  transition:.15s; cursor:pointer;
}
.child-card:hover{ background:var(--ink); color:var(--ivory); border-color:var(--ink) }
.child-card:hover .name em, .child-card:hover .age{ color:rgba(243,237,227,.7) }
.child-card.add{
  border-style:dashed; align-items:center; justify-content:center; text-align:center;
  background:transparent; color:var(--ink-60);
}
.child-card.add:hover{ background:var(--ivory-soft); color:var(--ink); border-color:var(--ink-15) }
.child-card .av{
  width:48px; height:48px; border-radius:50%;
  background:linear-gradient(135deg, var(--ocre-soft), var(--ocre));
  display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:22px; color:var(--ink);
}
.child-card .name{ font-family:var(--serif); font-size:24px; font-style:italic; font-weight:400; margin:0; line-height:1.1 }
.child-card .age{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; color:var(--ink-60); text-transform:uppercase; margin-top:2px }
.child-card.add .plus{ font-size:32px; font-weight:300; color:var(--ink-40); line-height:1 }

/* ── 3. TIMELINE ───────────────────────────────────────────── */
.t-back{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-60); margin-bottom:32px; cursor:pointer; display:inline-flex; align-items:center; gap:6px }
.t-back:hover{ color:var(--ink) }

.t-head{
  display:flex; align-items:center; gap:18px;
  border-top:1px solid var(--ink-15); border-bottom:1px solid var(--ink-15);
  padding:24px 0; margin-bottom:28px;
}
.t-head .av{ width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg, var(--ocre-soft), var(--ocre)); display:grid; place-items:center; font-family:var(--serif); font-style:italic; font-size:26px; color:var(--ink); flex-shrink:0 }
.t-head .name{ font-family:var(--serif); font-size:36px; font-style:italic; font-weight:400; line-height:1; letter-spacing:-.01em; margin:0 0 4px }
.t-head .meta{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-60) }
.t-head .meta .sep{ margin:0 8px; color:var(--ink-15) }
.t-head .actions{ margin-left:auto; display:flex; gap:8px; flex-wrap:wrap }

/* Tabs Timeline / Croissance */
.t-tabs{ display:flex; gap:0; border-bottom:1px solid var(--ink-15); margin-bottom:40px }
.t-tab{
  padding:14px 28px; font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-60); border-bottom:2px solid transparent; cursor:pointer;
  margin-bottom:-1px;
}
.t-tab:hover{ color:var(--ink) }
.t-tab.on{ color:var(--ink); border-bottom-color:var(--ocre) }

.t-section-head{
  display:flex; align-items:baseline; justify-content:space-between; gap:24px; margin-bottom:32px;
}
.t-section-head h2{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:36px; line-height:1; letter-spacing:-.01em; margin:0 }

/* Vertical line + moments */
.t-stream{ position:relative; padding-left:48px }
.t-stream::before{
  content:""; position:absolute; left:8px; top:8px; bottom:8px;
  width:1px; background:linear-gradient(180deg, var(--ocre) 0%, var(--ink-15) 100%);
}
.t-moment{ position:relative; margin-bottom:48px }
.t-moment::before{
  content:""; position:absolute; left:-44px; top:8px;
  width:13px; height:13px; border-radius:50%;
  background:var(--ivory); border:1.5px solid var(--ocre);
  box-shadow:0 0 0 4px var(--ivory);
}
.t-moment.milestone::before{ background:var(--ocre); border-color:var(--ocre-deep); width:15px; height:15px; left:-45px }

.t-moment .head{
  display:flex; align-items:baseline; justify-content:space-between; gap:14px;
  margin-bottom:14px;
}
.t-moment .head-left{ display:flex; align-items:baseline; gap:14px; flex-wrap:wrap }
.t-moment .glyph{ font-size:22px; line-height:1 }
.t-moment .date{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ocre-deep) }
.t-moment .badge{
  font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-60);
  padding:3px 10px; border:1px solid var(--ink-15); border-radius:999px;
}
.t-moment.milestone .badge{ color:var(--ocre-deep); border-color:var(--ocre); background:var(--ocre-soft) }

.t-moment h3{
  font-family:var(--serif); font-weight:500;
  font-size:32px; line-height:1.1; letter-spacing:-.01em;
  margin:0 0 14px;
}
.t-moment.milestone h3{ font-style:italic; font-weight:400 }
.t-moment p{ margin:0 0 14px; color:var(--ink); font-size:15.5px; line-height:1.6; max-width:62ch }

.t-moment .photo{
  width:100%; aspect-ratio:16/10; overflow:hidden;
  background:var(--ivory-deep);
}
.t-moment .photo img{ width:100%; height:100%; object-fit:cover }
.t-moment .photo.tall{ aspect-ratio:4/5 }
.t-moment .photo.placeholder{
  background:repeating-linear-gradient(45deg, var(--ink-08) 0 10px, transparent 10px 20px) var(--ivory-deep);
  display:grid; place-items:center; font-family:var(--mono); font-size:11px; color:var(--ink-40); letter-spacing:.08em;
}

.t-moment .actions{ display:flex; gap:6px; margin-top:14px }
.t-moment .actions button{
  font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-60); padding:6px 10px;
}
.t-moment .actions button:hover{ color:var(--ink) }
.t-moment .actions .danger:hover{ color:var(--ocre-deep) }

/* Empty / sober moment (texte seul, comme le 2e dans tes screenshots) */
.t-moment.text-only{ padding-bottom:0; margin-bottom:36px; border-bottom:1px dashed var(--ink-08); padding-bottom:24px }
.t-moment.text-only .photo{ display:none }

