:root {
  --bg:#faf9f6; --surface:#ffffff; --surface-2:#f4f1ec; --surface-3:#ece9e3;
  --border:rgba(30,20,10,.07); --border-soft:rgba(30,20,10,.04);
  --text:#1c1710; --text-muted:#78706a; --text-faint:#b5aca5;
  --accent:#bf5b43; --accent-hover:#a34a34;
  --teal:#4fba96; --purple:#8e83c9; --amber:#d9932a; --red:#d04f4e; --gray:#979790;
  --green:#5aaa5a; --blue:#4a8fd4;
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:26px;
  --sh-sm:0 2px 10px rgba(30,20,10,.06),0 1px 2px rgba(30,20,10,.04);
  --ease:cubic-bezier(.16,1,.3,1); --dur:200ms;
  --fd:'DM Serif Display',Georgia,serif; --fb:'DM Sans',system-ui,sans-serif;
}

/* Dark mode variables */
:root.dark {
  --bg:#1a1815; --surface:#2a2520; --surface-2:#3a3028; --surface-3:#4a3a30;
  --border:rgba(255,255,255,.1); --border-soft:rgba(255,255,255,.05);
  --text:#f5f0e8; --text-muted:#b5aca5; --text-faint:#78706a;
  --accent:#e67e5c; --accent-hover:#d06a4a;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{-webkit-font-smoothing:antialiased;}
body{background:var(--bg);font-family:var(--fb);font-size:15px;color:var(--text);min-height:100dvh;}
.app{max-width:460px;margin:0 auto;padding:2.75rem 1.25rem 5rem;}

/* Theme toggle */
.theme-toggle{position:fixed;top:20px;right:20px;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--dur) var(--ease);box-shadow:var(--sh-sm);}
.theme-toggle:hover{background:var(--surface-2);transform:scale(1.1);}
.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}

/* Onglets */
.tabs-container{margin-bottom:1.5rem;}
.tabs-nav{display:flex;gap:4px;background:var(--surface-2);border-radius:var(--r-lg);padding:4px;margin-bottom:1rem;}
.tab-btn{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:var(--r-md);
  font-family:var(--fb);font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;
  transition:background var(--dur),color var(--dur);white-space:nowrap;}
.tab-btn:hover{background:var(--surface-3);color:var(--text);}
.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px rgba(30,20,10,.08);}
.tab-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.tab-content{display:none;}
.tab-content.active{display:block;animation:fadeIn var(--dur) var(--ease);}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.header{text-align:center;margin-bottom:2.25rem;}
.header h1{font-family:var(--fd);font-size:clamp(2rem,9vw,2.75rem);font-weight:400;line-height:1.08;letter-spacing:-.015em;}
.header h1 em{font-style:italic;color:var(--accent);}
.header-date{font-size:13px;color:var(--text-muted);margin-top:6px;text-transform:capitalize;letter-spacing:.025em;}

/* Streak banner */
.streak-banner{background:linear-gradient(135deg,rgba(191,91,67,.1),rgba(217,147,42,.08));
  border:1px solid rgba(191,91,67,.18);border-radius:var(--r-lg);padding:.85rem 1.1rem;
  margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;}
.streak-banner.hidden{display:none;}
.streak-icon{font-size:1.8rem;line-height:1;flex-shrink:0;}
.streak-text{font-size:13px;color:var(--text);}
.streak-text strong{font-weight:600;color:var(--accent);}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.75rem;margin-bottom:1rem;box-shadow:var(--sh-sm);}
.section-label{font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:1.5rem;}
.slider-row{margin-bottom:1.75rem;}
.slider-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.slider-name{font-size:14px;font-weight:500;color:var(--text);}
.slider-tag{font-family:var(--fd);font-style:italic;font-size:15px;color:var(--accent);transition:opacity .15s ease;}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;
  background:linear-gradient(to right,var(--accent) var(--pct,50%),var(--surface-2) var(--pct,50%));
  border-radius:99px;outline:none;cursor:pointer;margin:6px 0 10px;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:var(--surface);border:2.5px solid var(--accent);box-shadow:0 1px 6px rgba(191,91,67,.35);
  transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease);}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25);box-shadow:0 2px 12px rgba(191,91,67,.5);}
input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--surface);border:2.5px solid var(--accent);}
input[type=range].energy-slider{background:linear-gradient(to right,var(--blue) var(--pct,50%),var(--surface-2) var(--pct,50%));}
input[type=range].energy-slider::-webkit-slider-thumb{border-color:var(--blue);box-shadow:0 1px 6px rgba(74,143,212,.35);}
input[type=range]:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:99px;}
.extremes{display:flex;justify-content:space-between;font-size:11px;color:var(--text-faint);}
.message-box{background:var(--surface-2);border-radius:var(--r-lg);padding:1.35rem 1.6rem;margin:1.5rem 0 1.25rem;
  min-height:92px;display:flex;align-items:center;justify-content:center;text-align:center;
  font-size:14.5px;line-height:1.7;color:var(--text);position:relative;overflow:hidden;transition:opacity .18s ease;}
.message-box::before{content:'\201C';font-family:var(--fd);font-size:88px;color:var(--accent);opacity:.065;
  position:absolute;top:-12px;left:8px;line-height:1;pointer-events:none;user-select:none;}

/* Champs journaux */
.journal-block{margin-bottom:1.5rem;}
.journal-label{font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px;display:block;line-height:1.5;}
.journal-label em{font-family:var(--fd);font-style:italic;color:var(--accent);}
textarea.journal-field{width:100%;min-height:72px;padding:.75rem .9rem;background:var(--surface-2);
  border:1px solid var(--border);border-radius:var(--r-md);font-family:var(--fb);font-size:13.5px;
  color:var(--text);line-height:1.65;resize:vertical;outline:none;
  transition:border-color var(--dur),box-shadow var(--dur);}
textarea.journal-field::placeholder{color:var(--text-faint);}
textarea.journal-field:focus{border-color:rgba(191,91,67,.35);box-shadow:0 0 0 3px rgba(191,91,67,.1);}
.char-count{font-size:11px;color:var(--text-faint);text-align:right;margin-top:4px;}
.char-count.warn{color:var(--amber);}

/* Carte question du jour */
.question-card{background:linear-gradient(135deg,rgba(79,186,150,.07),rgba(142,131,201,.05));
  border:1px solid rgba(79,186,150,.18);border-radius:var(--r-lg);padding:1rem 1.15rem;margin-bottom:1.5rem;}
.question-card-label{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--teal);margin-bottom:6px;}
.question-text{font-family:var(--fd);font-style:italic;font-size:16px;color:var(--text);line-height:1.4;}

/* Énergie */
.energy-row{margin-bottom:1.75rem;}
.energy-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.energy-label-text{font-size:14px;font-weight:500;color:var(--text);}
.energy-tag{font-family:var(--fd);font-style:italic;font-size:15px;color:var(--blue);}

/* Récap hebdo */
.recap-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);
  padding:1.75rem;margin-bottom:1rem;box-shadow:var(--sh-sm);}
.recap-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem;}
.recap-icon{font-size:1.3rem;}
.recap-title{font-family:var(--fd);font-size:17px;font-weight:400;color:var(--text);}
.recap-day{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-soft);}
.recap-day:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.recap-day-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;}
.recap-day-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.recap-day-name{font-size:12px;font-weight:600;color:var(--text);text-transform:capitalize;}
.recap-day-mood{font-size:11px;color:var(--text-muted);}
.recap-day-note{font-size:13px;color:var(--text-muted);line-height:1.5;font-style:italic;margin-top:2px;}
.recap-day-note.empty{color:var(--text-faint);font-style:normal;}
.recap-phrase{background:var(--surface-2);border-radius:var(--r-md);padding:.85rem 1rem;
  margin-top:1.1rem;font-family:var(--fd);font-style:italic;font-size:15px;color:var(--text);
  line-height:1.5;position:relative;}
.recap-phrase::before{content:'\201C';font-size:3rem;color:var(--accent);opacity:.12;position:absolute;top:-6px;left:8px;line-height:1;}
.recap-empty{text-align:center;padding:2rem 1rem;color:var(--text-faint);font-size:13px;}

.btn-primary{width:100%;padding:12px 16px;background:var(--accent);border:none;border-radius:var(--r-md);
  font-family:var(--fb);font-size:14px;font-weight:500;color:#fff;cursor:pointer;
  box-shadow:0 2px 10px rgba(191,91,67,.28);transition:background var(--dur) var(--ease),transform var(--dur) var(--ease);}
.btn-primary:hover{background:var(--accent-hover);}
.btn-primary:active{transform:scale(.97);}
.btn-primary:disabled{opacity:.55;cursor:not-allowed;}
.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.btn-primary.editing{background:var(--purple);box-shadow:0 2px 10px rgba(142,131,201,.35);}
.btn-primary.editing:hover{background:#7d6db8;}
.btn-ghost{width:100%;padding:10px 16px;background:transparent;border:1px solid var(--border);
  border-radius:var(--r-md);font-family:var(--fb);font-size:13px;color:var(--text-muted);
  cursor:pointer;margin-top:10px;transition:background var(--dur),color var(--dur);}
.btn-ghost:hover{background:var(--surface-2);color:var(--text);}
.btn-ghost:active{transform:scale(.98);}
.btn-ghost:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.save-status{text-align:center;font-size:12px;color:var(--text-muted);margin-top:10px;min-height:16px;}
.save-status.error{color:var(--red);}

.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;}
.cal-title{font-family:var(--fd);font-size:19px;font-weight:400;color:var(--text);text-transform:capitalize;}
.nav-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:var(--surface-2);border:none;border-radius:var(--r-sm);font-size:22px;
  color:var(--text-muted);cursor:pointer;transition:background var(--dur),color var(--dur);}
.nav-btn:hover{background:var(--surface-3);color:var(--text);}
.nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;}
.cal-day-name{text-align:center;font-size:10px;font-weight:600;color:var(--text-faint);
  letter-spacing:.07em;text-transform:uppercase;padding-bottom:8px;}
.cal-cell{aspect-ratio:1;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--text-muted);background:var(--surface-2);position:relative;
  transition:transform var(--dur) var(--ease);}
.cal-cell:not(.empty):hover{transform:scale(1.12);z-index:1;}
.cal-cell:not(.empty):not(.today):hover{background:var(--surface-3);cursor:pointer;}
.cal-cell.has-data{color:var(--text);font-weight:500;position:relative;}
.cal-cell.has-data::after{content:'';position:absolute;top:2px;right:2px;width:6px;height:6px;border-radius:50%;opacity:0.8;}
.cal-cell.today{box-shadow:0 0 0 1.5px var(--accent);color:var(--accent);font-weight:600;}
.cal-cell.empty{background:transparent;}
.dot{width:5px;height:5px;border-radius:50%;position:absolute;bottom:4px;left:50%;transform:translateX(-50%);}
.mood-teal{background:rgba(79,186,150,.16);}
.mood-teal.has-data::after{background:#4fba96;}
.mood-purple{background:rgba(142,131,201,.16);}
.mood-purple.has-data::after{background:#8e83c9;}
.mood-amber{background:rgba(217,147,42,.16);}
.mood-amber.has-data::after{background:#d9932a;}
.mood-red{background:rgba(208,79,78,.16);}
.mood-red.has-data::after{background:#d04f4e;}
.mood-gray{background:rgba(151,151,144,.11);}
.mood-gray.has-data::after{background:#979790;}
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px;padding-top:14px;border-top:1px solid var(--border-soft);}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);}
.legend-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:1.1rem;}
.stat-card{background:var(--surface-2);border-radius:var(--r-md);padding:13px 15px;}
.stat-label{font-size:10.5px;font-weight:500;color:var(--text-faint);text-transform:uppercase;letter-spacing:.07em;}
.stat-val{font-family:var(--fd);font-size:26px;color:var(--text);margin-top:4px;line-height:1.1;}
.stat-val.small{font-family:var(--fb);font-size:12px;font-weight:500;margin-top:6px;line-height:1.4;}
.chart-wrap{margin-top:1.1rem;background:var(--surface-2);border-radius:var(--r-md);padding:1.1rem 1rem .85rem;}
.chart-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.chart-label{font-size:10.5px;font-weight:500;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;}
.chart-legend{display:flex;gap:12px;}
.chart-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);}
.chart-legend-dot{width:7px;height:7px;border-radius:50%;}
#trend-chart{width:100%;height:110px;display:block;}
#confetti-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;}

/* Jardin d'humeur */
.garden-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:1.75rem;margin-bottom:1rem;box-shadow:var(--sh-sm);}
.garden-top{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;}
.garden-title{font-family:var(--fd);font-size:18px;font-weight:400;color:var(--text);}
.garden-sub{font-size:12px;color:var(--text-muted);line-height:1.5;max-width:28ch;}
.garden-stage{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;}
.garden-scene{position:relative;overflow:hidden;border-radius:var(--r-lg);background:linear-gradient(180deg,#f9f5ef 0%,#f4efe8 55%,#eadfcb 56%,#e4d2b5 100%);min-height:220px;padding:1rem 1rem 1.2rem;}
.garden-sky{position:absolute;inset:0 0 45% 0;background:linear-gradient(180deg,rgba(255,255,255,.65),rgba(255,255,255,0));pointer-events:none;}
.garden-rainbow{position:absolute;left:50%;top:18px;transform:translateX(-50%);width:260px;height:130px;opacity:0;transition:opacity .6s ease;pointer-events:none;}
.garden-rainbow.visible{opacity:1;animation:floaty 4s ease-in-out infinite;}
.arc{position:absolute;left:50%;transform:translateX(-50%);border-radius:999px 999px 0 0;border-bottom:none;}
.arc.a1{width:260px;height:130px;border:10px solid #ff6b6b;top:0}
.arc.a2{width:230px;height:115px;border:10px solid #ffb84d;top:13px}
.arc.a3{width:200px;height:100px;border:10px solid #ffe66d;top:26px}
.arc.a4{width:170px;height:85px;border:10px solid #6bcf8f;top:39px}
.arc.a5{width:140px;height:70px;border:10px solid #5dade2;top:52px}
.arc.a6{width:110px;height:55px;border:10px solid #b084f5;top:65px}
.garden-bed{position:relative;display:flex;align-items:flex-end;justify-content:center;gap:10px;min-height:170px;padding-top:40px;}
.plant-slot{position:relative;width:46px;height:150px;display:flex;align-items:flex-end;justify-content:center;}
.plant{position:relative;width:42px;height:130px;display:flex;align-items:flex-end;justify-content:center;filter:drop-shadow(0 3px 4px rgba(0,0,0,.08));}
.stem{position:absolute;bottom:18px;width:4px;background:#4b8a51;border-radius:99px;transform-origin:bottom center;}
.leaf{position:absolute;bottom:42px;width:16px;height:10px;background:#71b77a;border-radius:16px 16px 16px 0;}
.leaf.r{transform:scaleX(-1);}
.flower-core,.flower-petal,.bud,.sad-head,.droop{position:absolute}
.soil{position:absolute;left:50%;bottom:0;transform:translateX(-50%);width:34px;height:18px;background:#b7885b;border-radius:50%;}
.plant.good .stem{height:68px}.plant.good .flower-core{bottom:80px;width:14px;height:14px;background:#ffd166;border-radius:50%;left:50%;transform:translateX(-50%)}
.plant.good .flower-petal{width:12px;height:18px;background:#ff7eb6;border-radius:12px;bottom:78px;left:50%;transform-origin:center 18px}
.plant.good .flower-petal.p1{transform:translateX(-50%) rotate(0deg) translateY(-13px)}
.plant.good .flower-petal.p2{transform:translateX(-50%) rotate(72deg) translateY(-13px)}
.plant.good .flower-petal.p3{transform:translateX(-50%) rotate(144deg) translateY(-13px)}
.plant.good .flower-petal.p4{transform:translateX(-50%) rotate(216deg) translateY(-13px)}
.plant.good .flower-petal.p5{transform:translateX(-50%) rotate(288deg) translateY(-13px)}
.plant.good::after{content:'';position:absolute;bottom:95px;left:50%;transform:translateX(-50%);width:34px;height:34px;border-radius:50%;background:radial-gradient(circle,rgba(255,220,120,.55),rgba(255,220,120,0) 70%);animation:glow 2s ease-in-out infinite}
.plant.ok .stem{height:58px}.plant.ok .bud{bottom:73px;left:50%;transform:translateX(-50%);width:16px;height:20px;background:#c78df0;border-radius:50% 50% 45% 45%}
.plant.low .stem{height:42px;transform:rotate(8deg)}.plant.low .sad-head{bottom:52px;left:50%;transform:translateX(-20%);width:18px;height:18px;background:#90a4ae;border-radius:50%}.plant.low .droop{bottom:45px;left:50%;width:16px;height:10px;border:3px solid #90a4ae;border-top:none;border-left:none;border-right:none;border-radius:0 0 20px 20px;transform:translateX(-15%) rotate(18deg)}
.plant.watered .sad-head{background:#8ecae6}.plant.watered .droop{border-bottom-color:#8ecae6}.plant.watered .stem{background:#5d9b63}
.water-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:1rem}
.water-btn{padding:9px 12px;border:1px solid var(--border);background:var(--surface);border-radius:999px;font-size:12px;color:var(--text);cursor:pointer}
.water-btn:hover{background:var(--surface-2)}
.encouragement{margin-top:.8rem;background:var(--surface-2);border-radius:var(--r-md);padding:.8rem .9rem;font-size:13px;line-height:1.55;color:var(--text-muted);min-height:52px}
.garden-message{margin-top:1rem;background:linear-gradient(135deg,rgba(191,91,67,.08),rgba(79,186,150,.08));border:1px solid rgba(191,91,67,.15);border-radius:var(--r-md);padding:.95rem 1rem;font-size:13px;line-height:1.65;color:var(--text)}
.brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.site-logo {
  width: 42px;
  height: 42px;
  object-fit: contain;
  display: block;
  transform: translateY(3px);
}



@keyframes glow{50%{transform:translateX(-50%) scale(1.1);opacity:.75}}
@keyframes floaty{50%{transform:translateX(-50%) translateY(-4px)}}

/* Past entry form styles */
.past-entry-form{background:var(--surface-2);border-radius:var(--r-lg);padding:1.2rem;margin:1rem 0;border:1px solid var(--border);}
.past-date-selector{display:flex;flex-direction:column;gap:1rem;}
.date-picker{padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);font-family:var(--fb);font-size:14px;color:var(--text);outline:none;transition:border-color var(--dur),box-shadow var(--dur);}
.date-picker:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(191,91,67,.1);}
.date-picker::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(0.5);}
.date-picker::-moz-calendar-picker-indicator{cursor:pointer;filter:invert(0.5);}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}}
