/* ══════════════════════════════════════════════════════
   LUMOS SHARED CSS — importé par toutes les pages
   ══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fff8f0;--surface:#ffffff;--surface2:#fff1e0;--border:#f5c890;--border2:#e8a050;
  --text:#1a0a00;--muted:#8a5020;--muted2:#b06820;
  --accent:#c04800;--accent2:#e07000;
  --card-shadow:0 4px 20px rgba(180,80,0,0.10);
  --font-serif:'Playfair Display',Georgia,serif;
  --font-sans:'Nunito',system-ui,sans-serif;
}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans);overflow-x:hidden}
@supports(padding:max(0px)){body{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}
button{font-family:var(--font-sans);cursor:pointer;border:none;background:none}
input,textarea{font-family:var(--font-sans)}
textarea{resize:vertical}

/* ── ANIMATIONS ── */
@keyframes aur1{from{transform:translate(0,0)}to{transform:translate(50px,30px)}}
@keyframes aur2{from{transform:translate(0,0)}to{transform:translate(-30px,25px)}}
@keyframes float{from{transform:translate(0,0) scale(1)}to{transform:translate(var(--px,20px),var(--py,-20px)) scale(1.15)}}
@keyframes tw{from{opacity:0.04}to{opacity:var(--max-op,0.35)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes msgIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes dot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}

/* ── BACKGROUND ── */
#global-bg{position:fixed;inset:0;z-index:0;pointer-events:none}
.stars{position:fixed;inset:0;pointer-events:none;z-index:0}
.star{position:absolute;border-radius:50%;animation:tw var(--d) infinite alternate}
.aurora{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.aurora-blob{position:absolute;border-radius:50%;pointer-events:none}
.aurora-blob:nth-child(1){width:600px;height:600px;top:-200px;left:-100px;animation:aur1 9s ease-in-out infinite alternate}
.aurora-blob:nth-child(2){width:500px;height:500px;bottom:-100px;right:-50px;animation:aur2 11s ease-in-out infinite alternate}

/* ── LAYOUT ── */
.inner{position:relative;z-index:2;max-width:480px;margin:0 auto;padding:0 18px;width:100%}
.page-content{padding:20px 0 60px;position:relative;z-index:2}

/* ── TOPNAV ── */
.topnav{position:sticky;top:0;z-index:100;width:100%;background:rgba(255,248,240,0.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);padding:12px 18px;padding-top:max(12px,env(safe-area-inset-top));display:flex;align-items:center;justify-content:space-between;isolation:isolate}
.topnav-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:19px;color:var(--text);position:relative;z-index:2}
.avatar-btn{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:6px 14px;color:var(--text);font-size:13px;position:relative}
.dropdown{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface2);border:1px solid var(--border2);border-radius:12px;overflow:hidden;min-width:190px;z-index:200;display:none}
.dropdown.open{display:block}
.dropdown-item{padding:12px 16px;font-size:13px;color:var(--muted2);border-bottom:1px solid var(--border)}
.dropdown-item.danger{color:#f87171;cursor:pointer}
.dropdown-item.danger:hover{background:#1c0505}
.theme-picker{display:flex;gap:7px;padding:10px 14px;border-bottom:1px solid var(--border);align-items:center;flex-wrap:wrap}
.theme-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-right:4px}
.theme-swatch{width:24px;height:24px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:transform .15s,border-color .15s,box-shadow .15s;box-shadow:0 2px 6px rgba(0,0,0,0.4)}
.theme-swatch:hover{transform:scale(1.18);box-shadow:0 4px 12px rgba(0,0,0,0.5)}
.theme-swatch.active{border-color:#fff!important;box-shadow:0 0 0 3px rgba(255,255,255,0.3),0 4px 12px rgba(0,0,0,0.5)!important}

/* ── BOUTONS ── */
.btn-primary{width:100%;padding:14px;border-radius:14px;background:linear-gradient(135deg,#c04800,#e07000);color:#fff;font-size:15px;font-weight:700;transition:opacity .2s,transform .1s}
.btn-primary:hover{opacity:.9;transform:translateY(-1px)}
.btn-primary:disabled{opacity:.45;transform:none;cursor:not-allowed}
.btn-secondary{width:100%;padding:14px;border-radius:14px;background:transparent;color:var(--accent2);border:1px solid var(--accent2);font-size:15px;font-weight:600;transition:background .2s}
.btn-secondary:hover{background:rgba(129,140,248,.1)}
.btn-ghost-back{color:var(--accent2);font-size:13px;padding:4px 0;display:flex;align-items:center;gap:4px}
.btn-ghost-back:hover{opacity:.7}
.pdf-btn{width:100%;padding:14px;border-radius:14px;border:1px solid var(--accent2);background:transparent;color:var(--accent2);font-size:15px;font-weight:700;margin-top:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}
.pdf-btn:hover{background:var(--surface2)}
.chat-btn{width:100%;padding:14px;border-radius:14px;border:1.5px solid;border-image:linear-gradient(135deg,#7c3aed,#4f46e5) 1;background:linear-gradient(135deg,#7c3aed08,#4f46e508);color:#7c3aed;font-size:15px;font-weight:700;transition:background .2s,transform .1s}
.chat-btn:hover{background:linear-gradient(135deg,#7c3aed18,#4f46e518);transform:translateY(-1px)}
.calendar-btn{width:100%;padding:14px;border-radius:14px;border:1px solid var(--border2);background:var(--surface);color:var(--accent);font-size:15px;font-weight:600;transition:background .2s}
.calendar-btn:hover{background:rgba(129,140,248,.1)}

/* ── TOP BAR PAGE ── */
.top-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding-top:4px}
.top-bar-title{font-family:var(--font-serif);font-size:18px;color:var(--text);font-weight:700}

/* ── SECTION LABEL ── */
.section-label{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;margin-top:20px}

/* ── CARDS ── */
.stat-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:14px 8px;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--card-shadow)}
.stat-icon{font-size:20px}
.stat-value{color:var(--text);font-weight:800;font-size:21px}
.stat-label{color:var(--muted);font-size:11px}
.summary-card{margin-top:16px;padding:18px;border-radius:14px;border:1px solid;background:var(--surface)}
.summary-header{font-weight:700;font-size:13px;margin-bottom:10px}
.summary-resume{color:#c7d2f0;font-size:14px;line-height:1.8;margin-bottom:12px}
.tag-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.tag{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.signal-title,.positif-title{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;margin-top:10px}
.signal-item{font-size:13px;color:#a0aec8;margin:3px 0;padding-left:12px;border-left:2px solid}
.positif-item{font-size:13px;color:#6a8060;margin:3px 0}
.raw-text{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:16px;color:#8898c0;font-size:14px;line-height:1.9;font-family:var(--font-serif);white-space:pre-wrap}

/* ── FORM FIELDS ── */
.field-group{margin-bottom:16px}
label.field-label{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.field-input{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-size:15px;padding:12px 14px;outline:none;transition:border-color .2s}
.field-input:focus{border-color:var(--accent2)}
.error-box{background:#fff0f0;border:1px solid #d0000066;border-radius:10px;padding:10px 14px;color:#c00000;font-size:13px;margin-bottom:14px;display:none}
.error-box.show{display:block}
.journal-textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:14px;color:var(--text);font-size:15px;padding:16px;line-height:1.85;outline:none;font-family:var(--font-serif);transition:border-color .2s}
.journal-textarea:focus{border-color:var(--border2)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:flex-start;justify-content:center;padding:12px;padding-top:max(12px,env(safe-area-inset-top));overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .3s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal-box{background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:22px 20px;max-width:400px;width:calc(100% - 24px);margin:0 auto;box-shadow:0 20px 60px rgba(0,0,0,0.5);transform:translateY(20px);transition:transform .3s;max-height:85vh;overflow-y:auto}
.modal-overlay.open .modal-box{transform:translateY(0)}
.modal-title{font-family:var(--font-serif);font-size:20px;color:var(--text);margin-bottom:6px}
.modal-sub{color:var(--muted);font-size:13px;margin-bottom:20px;line-height:1.6}
.modal-section{margin-bottom:16px}
.modal-section-title{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.modal-btns{display:flex;gap:10px;margin-top:20px}
.modal-cancel{flex:1;padding:12px;border-radius:14px;background:transparent;color:var(--muted2);border:1px solid var(--border2);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}
.modal-cancel:hover{background:var(--surface2)}

/* ── RAPPEL ── */
.notif-box{background:var(--surface2);border:1px solid var(--border2);border-radius:14px;padding:16px;margin-top:16px}
.notif-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.notif-label{color:var(--text);font-size:14px;font-weight:600}
.notif-sub{color:var(--muted);font-size:11px;margin-top:2px}
.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border2);border-radius:12px;cursor:pointer;transition:.3s}
.toggle-slider:before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:white;border-radius:50%;transition:.3s}
.toggle-switch input:checked + .toggle-slider{background:var(--accent)}
.toggle-switch input:checked + .toggle-slider:before{transform:translateX(20px)}
.time-picker{margin-top:10px;display:none}
.time-picker.show{display:block}
.time-input{background:var(--surface);border:1px solid var(--border2);border-radius:10px;color:var(--text);font-size:15px;padding:10px 14px;width:100%}

/* ── FOOTER ── */
.apaisio-footer{text-align:center;padding:18px 0 32px;position:relative;z-index:1}
.apaisio-footer a{text-decoration:none;display:block;transition:opacity .2s}
.apaisio-footer a:hover{opacity:.7}
.apaisio-footer-name{font-family:var(--font-serif);font-size:13px;color:var(--muted2);font-style:italic}
.apaisio-footer-copy{font-size:10px;color:var(--muted2);opacity:.8;margin-top:3px;letter-spacing:.05em}
.apaisio-footer-link{font-size:11px;color:var(--accent2);margin-top:5px;opacity:.85;letter-spacing:.02em}

/* ── RESPONSIVE ── */
@media(max-width:380px){.stats-row{gap:6px}}
@media(orientation:landscape) and (max-height:500px){body::before{content:"🔄 Tourne ton téléphone en portrait";position:fixed;inset:0;background:var(--bg);color:var(--text);display:flex;align-items:center;justify-content:center;font-size:16px;z-index:99999;text-align:center;padding:20px}}
