/* ===== I&P — Indépendance & Performance — Styles ===== */
/* Fichier CSS extrait de index.html pour améliorer la maintenabilité */


:root{
  --bg:#050505;--bg2:#0a0a0f;--bg3:#111118;--bg4:#1a1a24;
  --gold:#FFD700;--gold2:#B8860B;--gold3:#FFF0A0;--gold-dim:rgba(255,215,0,.12);
  --text:#F0F0F0;--text2:#A0A0B0;--text3:#8080A0;
  --sante:#8B5CF6;--sante-dim:rgba(139,92,246,.15);--sante-color:#8B5CF6;
  --comp:#3B82F6;--comp-dim:rgba(59,130,246,.15);
  --argent:#10B981;--argent-dim:rgba(16,185,129,.15);
  --temps:#F59E0B;--temps-dim:rgba(245,158,11,.15);
  --impact:#EC4899;--impact-dim:rgba(236,72,153,.15);
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --shadow:0 8px 32px rgba(0,0,0,.6);--shadow-sm:0 4px 16px rgba(0,0,0,.4);
  --glass:rgba(255,255,255,.04);--glass-border:rgba(255,255,255,.08);
  --transition:.2s cubic-bezier(.4,0,.2,1);
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bottom:env(safe-area-inset-bottom,0px);
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}

/* LIGHT MODE OVERRIDES */
body.light-mode {
  background: #F8F8FC;
  color: #1A1A2E;
}
.light-mode .screen { background: #F8F8FC; }
.light-mode .modal-sheet { background: #FFFFFF; }
.light-mode .feed-card,
.light-mode .share-card,
.light-mode .profile-row,
.light-mode .pillar-card,
.light-mode .kpi-card { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
.light-mode .ai-bubble { background: rgba(0,0,0,.05); }
.light-mode .ai-msg.assistant .ai-bubble { background: rgba(99,102,241,.1); }
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;font-size:15px;line-height:1.5;overflow:hidden}
#app{height:100vh;max-width:100%;margin:0;position:relative;overflow:hidden;display:flex}

/* WATERMARK */
.watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:0;overflow:hidden}
.watermark span{font-family:'Playfair Display',serif;font-size:clamp(120px,35vw,280px);font-weight:900;color:rgba(255,215,0,.03);letter-spacing:-8px;user-select:none;white-space:nowrap}

/* SCREENS — chaque écran remplace complètement le précédent */
.screen{position:absolute;inset:0;left:72px;overflow-y:auto;overflow-x:hidden;background:var(--bg);display:none;padding-bottom:20px}
.screen.active{display:block}
.screen-full{padding-bottom:0;left:0}
#screen-landing.active{display:flex}
#screen-ai.active{display:flex;flex-direction:column;overflow:hidden}

/* SIDEBAR NAV */
#bottom-nav{position:fixed;left:0;top:0;bottom:0;width:72px;z-index:100;background:rgba(5,5,5,.98);backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);display:none;flex-direction:column;align-items:center;padding:16px 0;--text3:#8080A0}
#bottom-nav.visible{display:flex}
.nav-items{display:flex;flex-direction:column;width:100%;gap:2px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}
.nav-items::-webkit-scrollbar{display:none}
.nav-item{width:100%;display:flex;flex-direction:column;align-items:center;gap:3px;padding:12px 4px;cursor:pointer;border:none;background:none;color:var(--text3);transition:var(--transition);position:relative}
.nav-item.active{color:var(--gold)}
.nav-item svg{width:22px;height:22px;stroke-width:1.8}
.nav-item span{font-size:9px;font-weight:500;letter-spacing:.3px}
.nav-item .badge{position:absolute;top:6px;right:8px;background:var(--impact);color:#fff;font-size:9px;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* LANDING */
#screen-landing{background:var(--bg);flex-direction:column;padding:0}
#particles-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}
.landing-banner{background:linear-gradient(90deg,var(--gold2),var(--gold),var(--gold2));color:#000;text-align:center;font-size:11px;font-weight:700;letter-spacing:2px;padding:10px 16px;position:relative;z-index:1}
.landing-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;text-align:center;min-height:0;position:relative;z-index:1}
.landing-logo{font-family:'Playfair Display',serif;font-size:clamp(56px,18vw,96px);font-weight:900;color:var(--gold);letter-spacing:-4px;line-height:1;margin-bottom:4px}
.landing-tagline{font-size:10px;letter-spacing:4px;color:var(--text3);text-transform:uppercase;margin-bottom:28px}
.landing-headline{font-family:'Playfair Display',serif;font-size:clamp(24px,7vw,36px);font-weight:700;line-height:1.2;margin-bottom:8px}
.landing-headline em{color:var(--gold);font-style:italic}
.landing-sub{font-size:14px;color:var(--text2);max-width:320px;margin:0 auto 24px}
.landing-stats{display:flex;gap:0;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:28px;width:100%;max-width:340px}
.landing-stat{flex:1;padding:12px 8px;text-align:center;border-right:1px solid var(--glass-border)}
.landing-stat:last-child{border-right:none}
.landing-stat-num{font-size:18px;font-weight:700;color:var(--gold)}
.landing-stat-label{font-size:9px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.landing-form{width:100%;max-width:340px}
.btn-google{width:100%;padding:14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);margin-bottom:12px}
.btn-google:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}
.or-divider{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:var(--glass-border)}
.or-divider span{font-size:11px;color:var(--text3)}
.form-group{margin-bottom:10px}
.form-label{font-size:11px;font-weight:600;letter-spacing:1px;color:var(--text3);text-transform:uppercase;margin-bottom:6px;display:block}
.form-input{width:100%;padding:13px 16px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;transition:var(--transition);outline:none}
.form-input:focus{border-color:var(--gold);background:rgba(255,215,0,.05)}
.form-input::placeholder{color:var(--text3)}
.btn-primary{width:100%;padding:15px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);letter-spacing:.5px;margin-top:4px}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(255,215,0,.3)}
.btn-primary:active{transform:translateY(0)}
.landing-footer{font-size:11px;color:var(--text3);text-align:center;padding:12px 24px;padding-bottom:calc(12px + var(--safe-bottom))}
.btn-resume{background:none;border:none;color:var(--gold);font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;display:block;margin:8px auto 0}

/* QUIZ */
#screen-quiz{background:var(--bg);padding:0}
.quiz-header{padding:calc(20px + var(--safe-top)) 24px 16px;background:var(--bg)}
.quiz-progress-bar{height:3px;background:var(--bg4);border-radius:2px;overflow:hidden;margin-bottom:16px}
.quiz-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold));border-radius:2px;transition:width .4s ease}
.quiz-step{font-size:11px;color:var(--text3);letter-spacing:2px;text-transform:uppercase}
.quiz-body{padding:0 24px 32px}
.quiz-q-num{font-size:11px;color:var(--gold);letter-spacing:2px;font-weight:600;margin-bottom:8px}
.quiz-q-text{font-family:'Playfair Display',serif;font-size:clamp(18px,5vw,24px);font-weight:700;line-height:1.3;margin-bottom:6px}
.quiz-q-sub{font-size:13px;color:var(--text2);margin-bottom:24px}
.quiz-options{display:flex;flex-direction:column;gap:10px}
.quiz-option{padding:14px 16px;background:var(--glass);border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);display:flex;align-items:flex-start;gap:12px}
.quiz-option:hover{border-color:rgba(255,215,0,.3);background:var(--gold-dim)}
.quiz-option.selected{border-color:var(--gold);background:var(--gold-dim)}
.quiz-option-letter{width:28px;height:28px;border-radius:50%;background:var(--bg4);border:1.5px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text3);flex-shrink:0;transition:var(--transition)}
.quiz-option.selected .quiz-option-letter{background:var(--gold);border-color:var(--gold);color:#000}
.quiz-option-text{font-size:14px;line-height:1.4;padding-top:4px}
.quiz-option-sub{font-size:12px;color:var(--text3);margin-top:2px}
.quiz-input-field{width:100%;padding:13px 16px;background:var(--glass);border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;transition:var(--transition)}
.quiz-input-field:focus{border-color:var(--gold);background:var(--gold-dim)}
.quiz-nav{display:flex;gap:10px;margin-top:24px}
.btn-quiz-next{flex:1;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.btn-quiz-back{padding:14px 20px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);font-size:14px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}

/* RESULT */
#screen-result{background:var(--bg);padding:0;flex-direction:column;align-items:center;justify-content:center;min-height:100%}
/* ===== RESULT SCREEN REDESIGN ===== */
#screen-result.active{display:flex;flex-direction:column;overflow:hidden}
.result-bg{position:absolute;inset:0;z-index:0;pointer-events:none;transition:background .5s}

/* Hero image */
.result-hero{position:relative;z-index:1;width:100%;height:320px;flex-shrink:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:rgba(0,0,0,.3)}
.result-img{width:100%;height:100%;object-fit:cover;object-position:center top;border-bottom:2px solid var(--a-border,rgba(255,215,0,.2))}
.result-img-loader{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%}
.result-img-spinner{width:36px;height:36px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--a-color1,#D4AF37);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.result-scroll{position:relative;z-index:1;flex:1;min-height:0;overflow-y:auto;display:flex;justify-content:center;-webkit-overflow-scrolling:touch;padding-bottom:80px}
.result-inner{padding:24px 24px 40px;text-align:center;max-width:420px;width:100%}
.result-cta-bar{position:fixed;bottom:0;left:0;right:0;z-index:200;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:var(--bg);border-top:1px solid var(--glass-border)}

/* Visual rings */
.result-visual-wrap{position:relative;width:160px;height:160px;margin:0 auto 28px;display:flex;align-items:center;justify-content:center}
.result-ring{position:absolute;border-radius:50%}
.result-ring.r3{width:160px;height:160px;background:var(--a-glow,rgba(212,175,55,.2));animation:ring-pulse 3s ease-in-out infinite;animation-delay:.6s}
.result-ring.r2{width:120px;height:120px;background:var(--a-glow,rgba(212,175,55,.3));animation:ring-pulse 3s ease-in-out infinite;animation-delay:.3s}
.result-ring.r1{width:84px;height:84px;background:var(--a-glow,rgba(212,175,55,.4));animation:ring-pulse 3s ease-in-out infinite}
@keyframes ring-pulse{0%,100%{transform:scale(1);opacity:.25}50%{transform:scale(1.08);opacity:.45}}
.result-badge{width:90px;height:90px;border-radius:50%;background:var(--a-gradient,linear-gradient(135deg,#D4AF37,#FFD700));display:flex;align-items:center;justify-content:center;font-size:44px;position:relative;z-index:2;box-shadow:0 0 50px var(--a-glow,rgba(212,175,55,.5))}

.result-label{font-size:10px;font-weight:700;letter-spacing:3px;color:var(--a-color1,#D4AF37);text-transform:uppercase;margin-bottom:8px;opacity:.85}
.result-title{font-family:'Playfair Display',serif;font-size:34px;font-weight:700;color:#fff;margin-bottom:10px;line-height:1.2}
.result-tagline{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:22px;font-style:italic}

.result-traits{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:20px}
.result-trait{padding:6px 14px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.4px;background:var(--a-dim,rgba(212,175,55,.1));color:var(--a-color1,#D4AF37);border:1px solid var(--a-border,rgba(212,175,55,.25))}

.result-pillar-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:20px;font-size:13px;font-weight:600;margin-bottom:20px}
.result-desc{font-size:14px;color:var(--text2);line-height:1.7;margin-bottom:20px;text-align:left}
.result-rate-box{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px;margin-bottom:24px;text-align:left}
.result-rate-label{font-size:11px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.result-rate-value{font-size:26px;font-weight:800;color:var(--gold)}
.result-rate-sub{font-size:12px;color:var(--text2);margin-top:2px}

/* ===== ARCHETYPE CARD (DASHBOARD) ===== */
.archetype-dash-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:16px;cursor:pointer;transition:transform .2s,opacity .2s}
.archetype-dash-card:hover{transform:translateY(-1px);opacity:.9}
.archetype-dash-emoji{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.btn-start{width:100%;padding:16px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}

/* DASHBOARD */
#screen-dashboard{background:var(--bg)}
.dash-header{padding:calc(16px + var(--safe-top)) 20px 12px;display:flex;align-items:center;justify-content:space-between}
.dash-user{display:flex;align-items:center;gap:12px}
.dash-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#000;flex-shrink:0}
.dash-greeting{font-size:12px;color:var(--text3)}
.dash-name{font-size:17px;font-weight:700;line-height:1.2}
.dash-xp-area{text-align:right}
.dash-xp-label{font-size:10px;color:var(--text3);letter-spacing:1px}
.dash-xp-val{font-size:14px;font-weight:700;color:var(--gold)}
.xp-bar{height:auto;background:transparent;border-radius:2px;margin-top:5px;width:80px;display:flex;flex-direction:column;gap:2px}
.xp-bar-fill{height:3px;border-radius:2px;transition:width .6s ease;min-width:4px}
.xp-bar-indep{background:linear-gradient(90deg,var(--gold2),var(--gold))}
.xp-bar-perf{background:linear-gradient(90deg,#6D28D9,#8B5CF6)}
.dash-day-badge{display:inline-flex;align-items:center;gap:6px;background:var(--gold-dim);border:1px solid rgba(255,215,0,.2);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;color:var(--gold);margin-left:8px}
.dash-section{padding:0 16px 16px}
.dash-section-title{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:12px}

/* SCORES */
.scores-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.score-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;position:relative;overflow:hidden}
.score-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.score-card.independence::before{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.score-card.performance::before{background:linear-gradient(90deg,var(--sante),var(--comp))}
.score-label{font-size:9px;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:4px}
.score-value{font-size:28px;font-weight:700;line-height:1}
.score-card.independence .score-value{color:var(--gold)}
.score-card.performance .score-value{color:var(--sante)}
.score-sub{font-size:10px;color:var(--text3);margin-top:4px}

/* CHART */
.chart-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.chart-wrap{position:relative;height:160px;width:100%}
#perf-chart{max-height:160px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.chart-title{font-size:12px;font-weight:600;color:var(--text2)}
.chart-avg{font-size:11px;color:var(--text3)}
.chart-legend{display:flex;gap:12px;margin-top:8px}
.chart-legend-item{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--text3)}
.chart-legend-dot{width:8px;height:8px;border-radius:50%}

.chart-period-btn{font-size:10px;padding:3px 7px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.05);color:var(--text3);cursor:pointer;transition:all .2s}
.chart-period-active{border-color:rgba(255,215,0,.4)!important;background:rgba(255,215,0,.12)!important;color:var(--gold)!important;font-weight:700}

/* XAVIER SUGGESTION */
.xavier-card{background:linear-gradient(135deg,rgba(255,215,0,.08),rgba(255,215,0,.03));border:1px solid rgba(255,215,0,.2);border-radius:var(--radius);padding:14px 16px;margin-bottom:16px;display:none}
.xavier-card.visible{display:block}
.xavier-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.xavier-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.xavier-name{font-size:12px;font-weight:700;color:var(--gold)}
.xavier-role{font-size:10px;color:var(--text3)}
.xavier-msg{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:12px}
.xavier-btns{display:flex;gap:8px}
.btn-xavier-yes{flex:1;padding:9px;background:var(--gold);color:#000;font-size:12px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition)}
.btn-xavier-no{flex:1;padding:9px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);font-size:12px;font-weight:600;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition)}

/* TODAY EXERCISE */
.today-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin-bottom:16px;cursor:pointer;transition:var(--transition)}
.today-card:hover{border-color:rgba(255,215,0,.3);transform:translateY(-1px)}
.today-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.today-title{font-size:17px;font-weight:700;margin-bottom:6px;line-height:1.3}
.today-meta{display:flex;gap:10px;align-items:center;margin-bottom:12px}
.today-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text2)}
.today-desc{font-size:13px;color:var(--text2);line-height:1.5;margin-bottom:14px}
.btn-today{width:100%;padding:13px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}

/* PILLARS GRID */
.pillars-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}
.pillar-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px;cursor:pointer;transition:var(--transition);border-left:3px solid transparent;position:relative;overflow:hidden}
.pillar-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.pillar-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,currentColor,transparent 70%);opacity:.04;pointer-events:none}
.pillar-emoji{font-size:22px;margin-bottom:6px}
.pillar-pct{font-size:20px;font-weight:700;line-height:1}
.pillar-name{font-size:12px;font-weight:600;margin-top:2px}
.pillar-desc{font-size:10px;color:var(--text3);margin-top:3px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pillar-progress{height:3px;background:var(--bg4);border-radius:2px;margin-top:8px;overflow:hidden}
.pillar-progress-fill{height:100%;border-radius:2px;transition:width .5s ease}
.pillar-excount{font-size:10px;color:var(--text3);margin-top:5px}

/* XAVIER MESSAGES */
.xavier-msg-card{background:linear-gradient(135deg,rgba(255,215,0,.06),rgba(255,215,0,.02));border:1px solid rgba(255,215,0,.15);border-radius:var(--radius);padding:16px;margin-bottom:16px;display:none}
.xavier-msg-card.visible{display:block}
.xavier-msg-tag{font-size:10px;color:var(--gold);letter-spacing:2px;font-weight:700;margin-bottom:6px}
.xavier-msg-text{font-size:14px;color:var(--text);line-height:1.6;font-style:italic}
.xavier-msg-close{float:right;background:none;border:none;color:var(--text3);cursor:pointer;font-size:16px;margin-top:-4px}

/* EXERCISE SCREEN */
#screen-exercise{background:var(--bg);padding:0;flex-direction:column}
#screen-exercise.active{display:flex}
.ex-header{padding:calc(16px + var(--safe-top)) 20px 12px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--glass-border)}
.btn-back{width:36px;height:36px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--text);font-size:18px}
.ex-title-area{flex:1}
.ex-pillar-tag{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.ex-title{font-size:16px;font-weight:700;line-height:1.2}
.ex-body{flex:1;min-height:0;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}
.ex-desc{font-size:14px;color:var(--text2);line-height:1.6;margin-bottom:20px;padding:14px;background:var(--glass);border-radius:var(--radius-sm);border:1px solid var(--glass-border)}
.ex-steps{margin-bottom:20px}
.ex-step{display:flex;gap:12px;padding:12px 14px;margin-bottom:8px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer}
.ex-step.done{background:var(--gold-dim);border-color:rgba(255,215,0,.3);opacity:.6}
.ex-step-num{width:24px;height:24px;border-radius:50%;background:var(--bg4);border:1.5px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text3);flex-shrink:0;transition:var(--transition)}
.ex-step.done .ex-step-num{background:var(--gold);border-color:var(--gold);color:#000}
.ex-step-text{font-size:13px;line-height:1.4;padding-top:4px}
.timer-section{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:20px;margin-bottom:16px;text-align:center}
.timer-circle-wrap{position:relative;width:140px;height:140px;margin:0 auto 16px}
.timer-svg{width:100%;height:100%;transform:rotate(-90deg)}
.timer-track{fill:none;stroke:var(--bg4);stroke-width:6}
.timer-prog{fill:none;stroke:var(--gold);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1s linear;filter:drop-shadow(0 0 6px rgba(255,215,0,.5))}
.timer-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.timer-display{font-family:'DM Mono',monospace;font-size:28px;font-weight:700;color:var(--gold);letter-spacing:2px;line-height:1}
.timer-unit{font-size:10px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-top:3px}
.timer-btns{display:flex;gap:10px;justify-content:center}

/* ===== EXERCISE UPGRADES ===== */
.ex-defi-card{background:rgba(255,215,0,.05);border:1px solid rgba(255,215,0,.2);border-radius:16px;padding:14px 16px;margin-bottom:16px}
.ex-defi-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.ex-defi-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--gold2),var(--gold));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ex-defi-name{font-size:12px;font-weight:700;color:var(--gold)}
.ex-defi-sub{font-size:11px;color:var(--text3);margin-top:1px}
.ex-defi-msg{font-size:13px;color:var(--text);line-height:1.6}
.ex-defi-typing{display:flex;gap:4px;align-items:center;padding:4px 0}
.ex-defi-typing span{width:6px;height:6px;border-radius:50%;background:var(--gold);display:inline-block;animation:xaDot 1.2s infinite}
.ex-defi-typing span:nth-child(2){animation-delay:.2s}
.ex-defi-typing span:nth-child(3){animation-delay:.4s}

.ex-step.step-flash{animation:stepFlash .4s ease}
@keyframes stepFlash{0%{transform:scale(1)}50%{transform:scale(1.03);background:rgba(255,215,0,.12)}100%{transform:scale(1)}}
.xp-pop{position:fixed;top:40%;left:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;font-family:'DM Mono',monospace;font-size:48px;font-weight:800;color:var(--gold);text-shadow:0 0 30px rgba(255,215,0,.8);animation:xpPop .9s ease forwards}
@keyframes xpPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}30%{opacity:1;transform:translate(-50%,-60%) scale(1.2)}70%{opacity:1;transform:translate(-50%,-80%) scale(1)}100%{opacity:0;transform:translate(-50%,-120%) scale(.9)}}
.btn-timer{padding:10px 24px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);border:none}
.btn-timer.play{background:var(--gold);color:#000}
.btn-timer.pause{background:var(--glass);border:1px solid var(--glass-border);color:var(--text)}
.btn-timer.reset{background:var(--glass);border:1px solid var(--glass-border);color:var(--text2)}
.ex-ai-hint{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(139,92,246,.08));border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-sm);padding:14px;margin-bottom:16px}
.ex-ai-label{font-size:10px;color:var(--comp);letter-spacing:2px;font-weight:700;margin-bottom:6px}
.ex-ai-text{font-size:13px;color:var(--text2);line-height:1.5}
.ex-book-ref{font-size:11px;color:var(--text3);text-align:center;margin-bottom:16px;font-style:italic}
.btn-validate{width:100%;padding:16px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.btn-validate:disabled{opacity:.5;cursor:not-allowed}

/* STATS */
#screen-stats{background:var(--bg)}
.stats-header{padding:calc(16px + var(--safe-top)) 20px 16px}
.stats-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700}
.stats-sub{font-size:13px;color:var(--text2)}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 16px 16px}
.kpi-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px}
.kpi-icon{font-size:20px;margin-bottom:6px}
.kpi-val{font-size:26px;font-weight:700;color:var(--gold)}
.kpi-label{font-size:11px;color:var(--text3);margin-top:2px}
.stats-section{padding:0 16px 16px}
.pillar-stat-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pillar-stat-emoji{font-size:18px;width:28px;text-align:center}
.pillar-stat-info{flex:1}
.pillar-stat-name{font-size:12px;font-weight:600}
.pillar-stat-bar{height:6px;background:var(--bg4);border-radius:3px;margin-top:4px;overflow:hidden}
.pillar-stat-fill{height:100%;border-radius:3px;transition:width .5s ease}
.pillar-stat-pct{font-size:12px;font-weight:700;min-width:36px;text-align:right}
.badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:0 16px 16px}
.badge-item{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:12px 8px;text-align:center;transition:var(--transition)}
.badge-item.earned{border-color:rgba(255,215,0,.3);background:var(--gold-dim)}
.badge-item.locked{opacity:.4}
.badge-emoji{font-size:24px;margin-bottom:4px}
.badge-name{font-size:9px;color:var(--text3);line-height:1.2}

/* AI CHAT */
#screen-ai{background:var(--bg);flex-direction:column;padding:0}
.ai-header{padding:calc(16px + var(--safe-top)) 20px 0;border-bottom:1px solid var(--glass-border);flex-shrink:0}
.ai-header-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.ai-nav-tabs{display:flex;gap:0;border-top:1px solid var(--glass-border);margin:0 -20px}
.ai-nav-tab{flex:1;padding:10px 4px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text3);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);letter-spacing:.2px}
.ai-nav-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.ai-nav-tab:hover:not(.active){color:var(--text2)}
.ai-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--comp),var(--sante));display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.ai-name{font-size:15px;font-weight:700}
.ai-status{font-size:11px;color:var(--argent);display:flex;align-items:center;gap:4px}
.ai-status::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--argent);display:inline-block}
.ai-pills{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;flex-shrink:0}
.ai-pills::-webkit-scrollbar{display:none}
.ai-pill{padding:6px 12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;font-size:11px;font-weight:500;white-space:nowrap;cursor:pointer;transition:var(--transition);flex-shrink:0}
.ai-pill:hover{border-color:rgba(255,215,0,.3);color:var(--gold)}
.ai-messages{flex:1;min-height:0;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;-webkit-overflow-scrolling:touch}
.ai-msg{max-width:85%;display:flex;flex-direction:column;gap:4px}
.ai-msg.user{align-self:flex-end;align-items:flex-end}
.ai-msg.assistant{align-self:flex-start;align-items:flex-start}
.ai-bubble{padding:12px 14px;border-radius:16px;font-size:13px;line-height:1.6}
.ai-msg.user .ai-bubble{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;border-radius:16px 16px 4px 16px}
.ai-msg.assistant .ai-bubble{background:var(--bg3);border:1px solid var(--glass-border);color:var(--text);border-radius:16px 16px 16px 4px}
.ai-msg-time{font-size:10px;color:var(--text3)}
.ai-typing{display:flex;gap:4px;align-items:center;padding:12px 14px;background:var(--bg3);border:1px solid var(--glass-border);border-radius:16px 16px 16px 4px;width:fit-content}
.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--text3);animation:typing .8s infinite}
.ai-typing span:nth-child(2){animation-delay:.15s}
.ai-typing span:nth-child(3){animation-delay:.3s}
@keyframes typing{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.ai-input-area{padding:12px 16px;padding-bottom:calc(12px + var(--safe-bottom) + 60px);border-top:1px solid var(--glass-border);background:var(--bg2);flex-shrink:0}
.ai-input{flex:1;padding:12px 14px;background:var(--glass);border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;resize:none;max-height:100px;transition:var(--transition)}
.ai-input:focus{border-color:var(--gold)}
.ai-send-btn{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}
.ai-send-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px rgba(255,215,0,.3)}
.ai-send-btn svg{width:18px;height:18px}

/* NOTES */
#screen-notes{background:var(--bg)}
.notes-header{padding:calc(16px + var(--safe-top)) 20px 12px;display:flex;align-items:center;justify-content:space-between}
.notes-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700}
.btn-new-note{padding:8px 14px;background:var(--gold);color:#000;font-size:12px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition)}
.notes-tabs{display:flex;gap:6px;padding:0 16px 12px;overflow-x:auto;scrollbar-width:none}
.notes-tabs::-webkit-scrollbar{display:none}
.notes-tab{padding:7px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:var(--transition);flex-shrink:0}
.notes-tab.active{background:var(--gold-dim);border-color:rgba(255,215,0,.3);color:var(--gold)}
.notes-list{padding:0 16px;display:flex;flex-direction:column;gap:10px}
.note-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px;cursor:pointer;transition:var(--transition)}
.note-card:hover{border-color:rgba(255,215,0,.2)}
.note-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.note-card-title{font-size:14px;font-weight:600}
.note-card-date{font-size:10px;color:var(--text3)}
.note-card-preview{font-size:12px;color:var(--text2);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.note-card-pillar{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-top:6px}
.note-editor{padding:0 16px}
.note-editor-input{width:100%;padding:12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;margin-bottom:10px;transition:var(--transition)}
.note-editor-input:focus{border-color:var(--gold)}
.note-editor-area{width:100%;padding:14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;min-height:200px;resize:vertical;line-height:1.6;transition:var(--transition)}
.note-editor-area:focus{border-color:var(--gold)}
.note-editor-actions{display:flex;gap:8px;margin-top:10px}
.btn-save-note{flex:1;padding:12px;background:var(--gold);color:#000;font-size:13px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer}
.btn-cancel-note{padding:12px 16px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);font-size:13px;font-weight:600;border-radius:var(--radius-xs);cursor:pointer}
.note-ai-analyze{margin-top:10px;padding:10px 14px;background:var(--comp-dim);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-xs);font-size:12px;color:var(--comp);cursor:pointer;width:100%;text-align:center;font-weight:600}

/* TEMPLATES */
#screen-templates{background:var(--bg)}
.templates-header{padding:calc(16px + var(--safe-top)) 20px 16px}
.templates-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700}
.templates-sub{font-size:13px;color:var(--text2)}
.templates-grid{padding:0 16px;display:flex;flex-direction:column;gap:10px}
.template-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:var(--transition)}
.template-card:hover{border-color:rgba(255,215,0,.2);transform:translateY(-1px)}
.template-card-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.template-icon{width:40px;height:40px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.template-name{font-size:14px;font-weight:700}
.template-desc{font-size:12px;color:var(--text2);line-height:1.4}
.template-tag{display:inline-flex;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:600;margin-top:8px}
.template-modal{position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:200;display:none;align-items:flex-end;padding:0}
.template-modal.open{display:flex}
.template-modal-inner{background:var(--bg2);border-radius:var(--radius) var(--radius) 0 0;padding:24px;width:100%;max-height:80vh;overflow-y:auto}
.template-modal-title{font-size:18px;font-weight:700;margin-bottom:4px}
.template-modal-sub{font-size:12px;color:var(--text2);margin-bottom:16px}
.template-content{background:var(--bg3);border-radius:var(--radius-sm);padding:16px;font-size:13px;color:var(--text2);line-height:1.8;white-space:pre-wrap;font-family:'DM Mono',monospace;margin-bottom:16px}
.template-modal-btns{display:flex;gap:8px}
.btn-use-template{flex:1;padding:13px;background:var(--gold);color:#000;font-size:13px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer}
.btn-close-template{padding:13px 16px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);font-size:13px;border-radius:var(--radius-sm);cursor:pointer}

/* COMMUNITY */
#screen-community{background:var(--bg)}
.community-header{padding:calc(16px + var(--safe-top)) 20px 12px}
.community-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700}
.community-sub{font-size:13px;color:var(--text2);margin-bottom:12px}
.community-tabs{display:flex;gap:6px;margin-bottom:16px}
.community-tab{flex:1;padding:9px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-xs);font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:var(--transition)}
.community-tab.active{background:var(--gold-dim);border-color:rgba(255,215,0,.3);color:var(--gold)}
.feed-list{padding:0 16px;display:flex;flex-direction:column;gap:10px}
.feed-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px;transition:var(--transition)}
.feed-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.feed-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#000;flex-shrink:0}
.feed-user-info{flex:1}
.feed-username{font-size:13px;font-weight:600}
.feed-meta{font-size:10px;color:var(--text3)}
.feed-pillar-tag{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px}
.feed-content{font-size:13px;color:var(--text);line-height:1.5;margin-bottom:10px}
.feed-achievement{display:flex;align-items:center;gap:8px;padding:10px;background:var(--gold-dim);border:1px solid rgba(255,215,0,.2);border-radius:var(--radius-xs);margin-bottom:10px}
.feed-achievement-icon{font-size:20px}
.feed-achievement-text{font-size:12px;font-weight:600;color:var(--gold)}
.feed-actions{display:flex;gap:12px}
.feed-action{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text3);cursor:pointer;transition:var(--transition)}
.feed-action:hover{color:var(--gold)}
.share-section{padding:0 16px 16px}
.share-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin-bottom:12px}
.share-title{font-size:14px;font-weight:700;margin-bottom:4px}
.share-desc{font-size:12px;color:var(--text2);margin-bottom:12px}
.share-preview{background:var(--bg3);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px;border:1px solid var(--glass-border)}
.share-preview-title{font-size:16px;font-weight:700;color:var(--gold);margin-bottom:4px}
.share-preview-sub{font-size:12px;color:var(--text2)}
.share-btns{display:flex;gap:8px;flex-wrap:wrap}
.btn-share{padding:10px 16px;border-radius:var(--radius-xs);font-size:12px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;gap:6px;transition:var(--transition)}
.btn-share.twitter{background:#1DA1F2;color:#fff}
.btn-share.linkedin{background:#0A66C2;color:#fff}
.btn-share.whatsapp{background:#25D366;color:#fff}
.btn-share.copy{background:var(--glass);border:1px solid var(--glass-border);color:var(--text)}
.post-area{padding:0 16px 16px}
.post-textarea{width:100%;padding:14px;background:var(--glass);border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-family:'Inter',sans-serif;outline:none;min-height:100px;resize:none;margin-bottom:10px;transition:var(--transition)}
.post-textarea:focus{border-color:var(--gold)}
.post-pillar-select{display:flex;gap:6px;margin-bottom:10px;overflow-x:auto;scrollbar-width:none}
.post-pillar-btn{padding:6px 12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:12px;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:var(--transition)}
.post-pillar-btn.selected{background:var(--gold-dim);border-color:rgba(255,215,0,.3);color:var(--gold)}
.btn-post{width:100%;padding:13px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer}

/* PROFILE */
#screen-profile{background:var(--bg)}
.profile-header{padding:calc(16px + var(--safe-top)) 20px 20px;text-align:center}
.profile-avatar-big{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#000;margin:0 auto 12px;box-shadow:0 0 30px rgba(255,215,0,.2)}
.profile-name{font-size:22px;font-weight:700}
.profile-archetype{font-size:12px;color:var(--gold);letter-spacing:2px;text-transform:uppercase;margin-top:2px}
.profile-level{font-size:13px;color:var(--text2);margin-top:4px}
.profile-rate-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin:0 16px 16px;text-align:center}
.profile-rate-label{font-size:11px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px}
.profile-rate-value{font-size:32px;font-weight:700;color:var(--gold)}
.profile-rate-sub{font-size:12px;color:var(--text2);margin-top:4px}
.profile-rate-next{font-size:11px;color:var(--text3);margin-top:8px;padding-top:8px;border-top:1px solid var(--glass-border)}
.profile-section{padding:0 16px 16px}
.profile-section-title{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:10px}
.profile-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-bottom:8px;cursor:pointer;transition:var(--transition)}
.profile-row:hover{border-color:rgba(255,215,0,.2)}
.profile-row-left{display:flex;align-items:center;gap:10px}
.profile-row-icon{font-size:18px}
.profile-row-label{font-size:14px;font-weight:500}
.profile-row-value{font-size:13px;color:var(--text3)}
.profile-row-arrow{color:var(--text3);font-size:16px}
/* FAQ accordion */
.faq-item{border:1px solid var(--border);border-radius:12px;margin-bottom:8px;overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;cursor:pointer;gap:10px;transition:background .15s}
.faq-q:hover{background:rgba(255,255,255,.04)}
.faq-q span:first-child{font-size:13px;font-weight:600;color:#fff;line-height:1.4}
.faq-arrow{color:var(--gold);font-size:18px;flex-shrink:0;transition:transform .2s;display:inline-block}
.faq-item.open .faq-arrow{transform:rotate(90deg)}
.faq-a{font-size:13px;color:var(--text2);line-height:1.7;padding:0 16px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease}
.faq-item.open .faq-a{max-height:400px;padding:0 16px 14px}
.api-key-input{width:100%;padding:12px;background:var(--glass);border:1.5px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;font-family:'DM Mono',monospace;outline:none;margin-bottom:8px;transition:var(--transition)}
.api-key-input:focus{border-color:var(--gold)}
.btn-save-api{width:100%;padding:12px;background:var(--gold);color:#000;font-size:13px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer}


/* ===== FORMATIONS ===== */
#screen-formations{background:var(--bg);overflow-y:auto;padding-bottom:80px}
.formations-header{padding:calc(16px + var(--safe-top)) 16px 16px;background:linear-gradient(180deg,rgba(5,5,5,1) 0%,rgba(5,5,5,0) 100%);position:sticky;top:0;z-index:10}
#biblio-section-formations .formations-header{padding:8px 16px 12px;position:relative}
.formations-title{font-size:22px;font-weight:700;font-family:'Playfair Display',serif}
.formations-title span{color:var(--gold)}
.formations-subtitle{font-size:12px;color:var(--text2);margin-top:4px}
.formation-card{margin:0 16px 16px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;transition:var(--transition);cursor:pointer}
.formation-card:hover{border-color:rgba(255,215,0,.3);transform:translateY(-2px)}
.formation-card-header{padding:20px;position:relative}
.formation-card-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:10px}
.formation-card-badge.free{background:rgba(16,185,129,.15);color:#10B981;border:1px solid rgba(16,185,129,.3)}
.formation-card-badge.premium{background:rgba(255,215,0,.1);color:var(--gold);border:1px solid rgba(255,215,0,.2)}
.formation-card-title{font-size:18px;font-weight:700;margin-bottom:6px}
.formation-card-subtitle{font-size:12px;color:var(--text2);margin-bottom:12px}
.formation-card-promise{font-size:12px;color:var(--text2);font-style:italic;padding:10px;background:rgba(255,255,255,.03);border-radius:var(--radius-xs);border-left:3px solid var(--gold);margin-bottom:12px}
.formation-card-meta{display:flex;gap:12px}
.formation-card-meta-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text3)}
.formation-card-chevron{float:right;color:var(--text3);font-size:12px;transition:transform .3s;display:inline-block}
.formation-card.open .formation-card-chevron{transform:rotate(180deg)}
.formation-card-modules{padding:0 20px 20px;display:none;flex-direction:column;gap:6px}
.formation-card.open .formation-card-modules{display:flex}
.formation-module-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(255,255,255,.03);border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition)}
.formation-module-row:hover{background:rgba(255,215,0,.05);border-color:rgba(255,215,0,.1)}
.formation-module-row.completed{opacity:.7}
.formation-module-num{width:24px;height:24px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text3);flex-shrink:0}
.formation-module-row.completed .formation-module-num{background:rgba(16,185,129,.2);border-color:#10B981;color:#10B981}
.formation-module-info{flex:1}
.formation-module-title{font-size:13px;font-weight:600}
.formation-module-duration{font-size:11px;color:var(--text3)}
.formation-module-check{font-size:14px;color:#10B981}
.formation-lock{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:rgba(255,215,0,.05);border-top:1px solid rgba(255,215,0,.1)}
.formation-lock-text{font-size:12px;color:var(--gold)}
.formation-lock-btn{padding:8px 16px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:12px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer}

/* MODULE DETAIL */
#screen-module{background:var(--bg);overflow-y:auto;padding-bottom:80px}
.module-header{padding:calc(16px + var(--safe-top)) 16px 16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;background:var(--bg);z-index:10;border-bottom:1px solid var(--glass-border)}
.module-back{background:none;border:none;color:var(--text);font-size:20px;cursor:pointer;padding:4px 8px}
.module-header-info{flex:1}
.module-header-title{font-size:15px;font-weight:700}
.module-header-meta{font-size:11px;color:var(--text3)}
.module-body{padding:16px}
.module-intro{font-size:14px;line-height:1.7;color:var(--text2);margin-bottom:20px;padding:16px;background:var(--glass);border-radius:var(--radius-sm);border-left:3px solid var(--gold)}
.module-section-title{font-size:11px;font-weight:700;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:12px;margin-top:20px}
.module-concept{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px}
.module-concept-title{font-size:13px;font-weight:700;color:var(--gold);margin-bottom:6px}
.module-concept-content{font-size:13px;color:var(--text2);line-height:1.6;white-space:pre-line}
.module-exercise{background:rgba(255,215,0,.05);border:1px solid rgba(255,215,0,.15);border-radius:var(--radius-sm);padding:16px;margin-bottom:16px}
.module-exercise-title{font-size:14px;font-weight:700;margin-bottom:6px}
.module-exercise-instructions{font-size:12px;color:var(--text2);margin-bottom:12px;font-style:italic}
.module-question{padding:10px 0;border-bottom:1px solid var(--glass-border)}
.module-question:last-child{border-bottom:none}
.module-question-text{font-size:13px;color:var(--text2);margin-bottom:8px}
.module-answer-input{width:100%;padding:10px 12px;background:var(--bg3);border:1.5px solid var(--glass-border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;font-family:'Inter',sans-serif;outline:none;resize:none;min-height:60px;transition:var(--transition)}
.module-answer-input:focus{border-color:var(--gold)}
.module-reflection{background:rgba(139,92,246,.08);border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-xs);padding:12px;margin-top:12px;font-size:12px;color:var(--text2);font-style:italic}
.module-tools{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.module-tool{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-xs)}
.module-tool-name{font-size:13px;font-weight:700}
.module-tool-badge{display:inline-block;padding:2px 6px;border-radius:6px;font-size:9px;font-weight:700;margin-left:6px}
.module-tool-badge.free{background:rgba(16,185,129,.15);color:#10B981}
.module-tool-badge.paid{background:rgba(239,68,68,.15);color:#ef4444}
.module-tool-badge.freemium{background:rgba(245,158,11,.15);color:#f59e0b}
.module-tool-usage{font-size:12px;color:var(--text2);margin-top:2px}
.module-tool-pros-cons{display:flex;gap:8px;margin-top:6px}
.module-tool-pro{font-size:11px;color:#10B981}
.module-tool-con{font-size:11px;color:#f87171}
.module-tool-link{font-size:11px;color:var(--gold);text-decoration:none;margin-top:4px;display:block}
.module-source{font-size:11px;color:var(--text3);font-style:italic;padding:12px;background:var(--glass);border-radius:var(--radius-xs);margin-bottom:16px}
.module-complete-btn{width:100%;padding:16px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:15px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;margin-top:16px;transition:var(--transition)}
.module-complete-btn:hover{opacity:.9;transform:translateY(-1px)}
.module-complete-btn.done{background:rgba(16,185,129,.2);color:#10B981;border:1px solid rgba(16,185,129,.3)}
.module-progress{display:flex;gap:4px;padding:0 16px 12px;overflow-x:auto;scrollbar-width:none}
.module-progress-dot{width:8px;height:8px;border-radius:50%;background:var(--glass);border:1px solid var(--glass-border);flex-shrink:0;transition:var(--transition)}
.module-progress-dot.active{background:var(--gold);border-color:var(--gold)}
.module-progress-dot.done{background:#10B981;border-color:#10B981}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:none;align-items:flex-end;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal-sheet{background:var(--bg2);border-radius:var(--radius) var(--radius) 0 0;padding:24px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:40px;height:4px;background:var(--bg4);border-radius:2px;margin:0 auto 20px}

/* Paywall supprimé — BETA */

/* RATING MODAL */
#rating-modal .modal-sheet{text-align:center}
.rating-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:6px}
.rating-sub{font-size:13px;color:var(--text2);margin-bottom:20px}
.stars-row{display:flex;justify-content:center;gap:12px;margin-bottom:20px}
.star-btn{font-size:36px;cursor:pointer;transition:var(--transition);opacity:.3;background:none;border:none}
.star-btn.active{opacity:1}
.rating-msg{font-size:13px;color:var(--text2);min-height:40px;margin-bottom:16px;line-height:1.5}
.btn-rate-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:8px}
.btn-rate-later{background:none;border:none;color:var(--text3);font-size:12px;cursor:pointer;text-decoration:underline}

/* XP POPUP */
#xp-popup{position:fixed;top:80px;left:50%;transform:translateX(-50%) translateY(-20px);background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;padding:12px 24px;border-radius:30px;font-size:14px;font-weight:700;z-index:400;opacity:0;transition:all .4s ease;pointer-events:none;box-shadow:0 8px 24px rgba(255,215,0,.4);white-space:nowrap}
#xp-popup.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* TOAST */
#toast{position:fixed;bottom:calc(80px + var(--safe-bottom));left:50%;transform:translateX(-50%) translateY(20px);background:var(--bg3,#1a1a24);border:1px solid var(--glass-border);color:var(--text,#F0F0F0);padding:10px 20px;border-radius:30px;font-size:13px;z-index:500;opacity:0;transition:all .3s ease;pointer-events:none;white-space:nowrap;max-width:90vw}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* PILLAR DETAIL */
#pillar-detail{position:fixed;inset:0;background:var(--bg);z-index:200;display:none;flex-direction:column;overflow:hidden}
#pillar-detail.open{display:flex}
.pillar-detail-header{padding:calc(16px + var(--safe-top)) 20px 12px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--glass-border);flex-shrink:0}
.pillar-detail-body{flex:1;min-height:0;overflow-y:auto;padding:16px;-webkit-overflow-scrolling:touch}
.pillar-detail-promise{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin-bottom:16px}
.pillar-detail-promise-title{font-size:11px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.pillar-detail-promise-text{font-size:15px;font-weight:600;line-height:1.4}
.pillar-exercises-list{display:flex;flex-direction:column;gap:8px}
.pillar-ex-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.pillar-ex-item:hover{border-color:rgba(255,215,0,.2)}
.pillar-ex-item.completed{background:var(--gold-dim);border-color:rgba(255,215,0,.2)}
.pillar-ex-day{font-size:11px;font-weight:700;color:var(--text3);min-width:36px}
.pillar-ex-info{flex:1}
.pillar-ex-title{font-size:13px;font-weight:600}
.pillar-ex-meta{font-size:11px;color:var(--text3);margin-top:2px}
.pillar-ex-check{font-size:16px}

/* LEVEL BADGE */
.level-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.5px}
.level-badge.debutant{background:rgba(16,185,129,.15);color:var(--argent)}
.level-badge.expert{background:var(--comp-dim);color:var(--comp)}
.level-badge.maitre{background:var(--gold-dim);color:var(--gold)}

/* PDF BILAN */
#pdf-modal .modal-sheet{text-align:center}
.pdf-preview{background:var(--bg3);border-radius:var(--radius-sm);padding:20px;margin-bottom:16px;text-align:left;border:1px solid var(--glass-border)}
.pdf-preview-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--gold);margin-bottom:4px}
.pdf-preview-sub{font-size:12px;color:var(--text3);margin-bottom:16px}
.pdf-section{margin-bottom:12px}
.pdf-section-title{font-size:10px;color:var(--text3);letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.pdf-pillar-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.pdf-pillar-name{font-size:12px}
.pdf-pillar-score{font-size:12px;font-weight:700}
.btn-download-pdf{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;margin-bottom:8px}
.btn-share-pdf{width:100%;padding:12px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text);font-size:13px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer}

/* ===== OUTILS GRILLE ===== */
.outils-cat{margin-bottom:20px}
.outils-cat-title{font-size:11px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--text3);margin-bottom:10px;padding-left:2px}
.outils-cat-items{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.outils-item-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 8px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);cursor:pointer;transition:var(--transition);font-size:22px}
.outils-item-btn span{font-size:11px;font-weight:600;color:var(--text2);text-align:center;line-height:1.2}
.outils-item-btn:hover{border-color:rgba(255,215,0,.3);background:rgba(255,215,0,.06);transform:translateY(-1px)}
.outils-item-btn:active{transform:scale(.96)}

/* ===== ZEN SPACE ===== */
#screen-zen{background:var(--bg);overflow-y:auto;padding-bottom:80px}
.zen-header{padding:calc(16px + var(--safe-top)) 20px 16px;background:linear-gradient(180deg,rgba(5,5,5,1),transparent);position:sticky;top:0;z-index:10}
.zen-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700}
.zen-title span{color:var(--sante)}
.zen-subtitle{font-size:12px;color:var(--text2);margin-top:4px}
.zen-tabs{display:flex;gap:6px;padding:0 16px 16px;overflow-x:auto;scrollbar-width:none}
.zen-tabs::-webkit-scrollbar{display:none}
.zen-tab{padding:8px 16px;background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:var(--transition);flex-shrink:0}
.zen-tab.active{background:rgba(139,92,246,.15);border-color:rgba(139,92,246,.4);color:var(--sante)}
.zen-section{padding:0 16px 16px}
.zen-section-title{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--text3);text-transform:uppercase;margin-bottom:12px}

/* LECTEUR AUDIO */
.zen-player{background:linear-gradient(135deg,rgba(139,92,246,.15),rgba(59,130,246,.1));border:1px solid rgba(139,92,246,.3);border-radius:var(--radius);padding:20px;margin:0 16px 16px;position:sticky;top:80px;z-index:5}
.zen-player-track{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.zen-player-cover{width:52px;height:52px;border-radius:var(--radius-xs);background:linear-gradient(135deg,var(--sante),var(--comp));display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
.zen-player-info{flex:1;min-width:0}
.zen-player-title{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zen-player-artist{font-size:11px;color:var(--text3);margin-top:2px}
.zen-player-badge{font-size:9px;padding:2px 6px;background:rgba(139,92,246,.2);color:var(--sante);border-radius:8px;font-weight:700;margin-top:4px;display:inline-block}
.zen-progress-bar{width:100%;height:3px;background:rgba(255,255,255,.1);border-radius:2px;margin-bottom:12px;cursor:pointer;position:relative}
.zen-progress-fill{height:100%;background:linear-gradient(90deg,var(--sante),var(--comp));border-radius:2px;transition:width .1s linear;width:0%}
.zen-controls{display:flex;align-items:center;justify-content:center;gap:20px}
.zen-ctrl-btn{background:none;border:none;color:var(--text2);cursor:pointer;padding:8px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.zen-ctrl-btn:hover{color:var(--text);background:rgba(255,255,255,.05)}
.zen-ctrl-btn svg{width:20px;height:20px}
.zen-play-btn{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--sante),var(--comp));border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);box-shadow:0 4px 20px rgba(139,92,246,.4)}
.zen-play-btn:hover{transform:scale(1.05)}
.zen-play-btn svg{width:22px;height:22px;fill:white}
.zen-time{font-size:10px;color:var(--text3);display:flex;justify-content:space-between;margin-top:6px}

/* CARDS AUDIO */
.zen-track-list{display:flex;flex-direction:column;gap:8px}
.zen-track-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.zen-track-card:hover{border-color:rgba(139,92,246,.3);background:rgba(139,92,246,.05)}
.zen-track-card.playing{border-color:rgba(139,92,246,.5);background:rgba(139,92,246,.1)}
.zen-track-emoji{font-size:24px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg3);border-radius:var(--radius-xs);flex-shrink:0}
.zen-track-info{flex:1;min-width:0}
.zen-track-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.zen-track-meta{font-size:11px;color:var(--text3);margin-top:2px}
.zen-track-pillar{font-size:9px;padding:2px 6px;border-radius:8px;font-weight:700;margin-top:3px;display:inline-block}
.zen-track-play{width:32px;height:32px;border-radius:50%;background:rgba(139,92,246,.2);border:1px solid rgba(139,92,246,.3);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:var(--transition)}
.zen-track-card.playing .zen-track-play{background:var(--sante)}
.zen-track-play svg{width:14px;height:14px;fill:var(--sante)}
.zen-track-card.playing .zen-track-play svg{fill:white}

/* BIBLIOTHÈQUE UNIFIÉE */
#screen-bibliotheque{background:var(--bg);overflow-y:auto;padding-bottom:80px}
.biblio-header{padding:calc(16px + var(--safe-top)) 16px 0;background:var(--bg);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--glass-border)}
.biblio-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:10px}
.biblio-title span{color:var(--gold)}
.biblio-main-tabs{display:flex;gap:0}
.biblio-main-tab{flex:1;padding:10px 6px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);text-align:center}
.biblio-main-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.biblio-section{display:none}
.biblio-section.active{display:block}
.library-sub-header{padding:12px 16px 0}
.library-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:700}
.library-title span{color:var(--gold)}
.library-subtitle{font-size:12px;color:var(--text2);margin-top:4px}
.library-tabs{display:flex;gap:8px;padding:12px 0 14px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.library-tabs::-webkit-scrollbar{display:none}
.library-tab{padding:8px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:var(--transition);flex-shrink:0;min-width:fit-content;color:var(--text)}
.library-tab.active{background:var(--gold-dim);border-color:rgba(255,215,0,.3);color:var(--gold)}
.library-grid{padding:16px 16px 0;display:flex;flex-direction:column;gap:12px}
.book-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);overflow:hidden;transition:var(--transition)}
.book-card:hover{border-color:rgba(255,215,0,.2);transform:translateY(-1px)}
.book-card-header{display:flex;gap:14px;padding:16px}
.book-cover{width:60px;height:84px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0;position:relative;overflow:hidden}
.book-cover-bg{position:absolute;inset:0;opacity:.3}
.book-cover-emoji{position:relative;z-index:1}
.book-info{flex:1;min-width:0}
.book-title{font-size:14px;font-weight:700;margin-bottom:3px}
.book-author{font-size:11px;color:var(--text3);margin-bottom:6px}
.book-pillar-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:10px;font-size:10px;font-weight:700;margin-bottom:6px}
.book-free-badge{display:inline-block;padding:2px 8px;background:rgba(16,185,129,.15);color:#10B981;border:1px solid rgba(16,185,129,.3);border-radius:8px;font-size:9px;font-weight:700;margin-left:6px}
.book-summary{font-size:12px;color:var(--text2);line-height:1.5;padding:0 16px 12px}
.book-key-ideas{padding:0 16px 12px}
.book-key-title{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--text3);text-transform:uppercase;margin-bottom:8px}
.book-key-item{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text2);margin-bottom:6px;line-height:1.4}
.book-key-item::before{content:'→';color:var(--gold);flex-shrink:0;margin-top:1px}
.book-actions{display:flex;gap:8px;padding:0 16px 16px}
.btn-read-book{flex:1;padding:10px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:12px;font-weight:700;border:none;border-radius:var(--radius-xs);cursor:pointer;text-decoration:none;text-align:center;display:block}
.btn-read-book:hover{opacity:.9}
.btn-save-book{padding:10px 14px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);font-size:12px;font-weight:600;border-radius:var(--radius-xs);cursor:pointer;transition:var(--transition)}
.btn-save-book.saved{border-color:rgba(255,215,0,.3);color:var(--gold)}

/* PODCAST CARDS */
.zen-podcast-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-bottom:8px;overflow:hidden;transition:var(--transition);cursor:pointer}
.zen-podcast-card:hover{border-color:rgba(139,92,246,.3);background:rgba(139,92,246,.05)}
.zen-podcast-card.playing{border-color:rgba(255,215,0,.5);background:rgba(255,215,0,.06)}
.zen-podcast-header{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;cursor:pointer}
.zen-podcast-toggle{flex-shrink:0;color:var(--text3);transition:transform .2s ease;margin-top:4px}
.zen-podcast-player{padding:0 14px 14px}
.zen-youtube-player{margin-bottom:16px;border-radius:12px;overflow:hidden;background:#000}

/* DÉFIS IA */
.defi-card{background:linear-gradient(135deg,rgba(255,215,0,.08),rgba(255,215,0,.03));border:1px solid rgba(255,215,0,.2);border-radius:var(--radius);padding:20px;margin:0 16px 16px}
.defi-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.defi-icon{font-size:32px}
.defi-meta{flex:1}
.defi-label{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gold);text-transform:uppercase}
.defi-title{font-size:16px;font-weight:700;margin-top:2px}
.defi-duration{font-size:11px;color:var(--text3);margin-top:2px}
.defi-desc{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:16px}
.defi-steps{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.defi-step{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--text2)}
.defi-step-num{width:20px;height:20px;border-radius:50%;background:rgba(255,215,0,.15);border:1px solid rgba(255,215,0,.3);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--gold);flex-shrink:0}
.defi-btns{display:flex;gap:10px}
.btn-accept-defi{flex:1;padding:13px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:13px;font-weight:700;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}
.btn-accept-defi:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(255,215,0,.3)}
.btn-refuse-defi{padding:13px 16px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text3);font-size:13px;font-weight:600;border-radius:var(--radius-sm);cursor:pointer}
.defi-progress{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:16px;margin:0 16px 16px}
.defi-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.defi-progress-title{font-size:13px;font-weight:700}
.defi-progress-days{font-size:11px;color:var(--gold)}
.defi-progress-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden}
.defi-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold2));border-radius:3px;transition:width .5s ease}
.defi-checklist{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.defi-check-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:var(--radius-xs);font-size:12px;cursor:pointer;transition:var(--transition)}
.defi-check-item.done{color:var(--argent);text-decoration:line-through;opacity:.6}
.defi-check-item::before{content:'○';color:var(--text3);font-size:14px;flex-shrink:0}
.defi-check-item.done::before{content:'✓';color:var(--argent)}

/* MÉMOIRE IA */
.ai-memory-card{background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-sm);padding:12px;margin:0 16px 12px}
.ai-memory-title{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--comp);text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.ai-memory-text{font-size:12px;color:var(--text2);line-height:1.5}

/* RESPONSIVE */
@media(min-width:480px){
  .landing-hero{padding:40px 32px}
  .pillars-grid{grid-template-columns:repeat(3,1fr)}
}
@media(min-width:768px){
  .scores-grid{grid-template-columns:repeat(4,1fr)}
  .kpi-grid{grid-template-columns:repeat(4,1fr)}
}

/* ===== MOBILE NAV TOGGLE ===== */
#nav-toggle{display:none}
/* Cacher hamburger sur les écrans sans sidebar */
body:has(#screen-landing.active) #nav-toggle,
body:has(#screen-otp.active) #nav-toggle,
body:has(#screen-quiz.active) #nav-toggle,
body:has(#screen-xavier-onboarding.active) #nav-toggle,
body:has(#screen-result.active) #nav-toggle{display:none!important}
#nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:99;backdrop-filter:blur(3px)}
#nav-overlay.visible{display:block}
#nav-close{display:none}

@media(max-width:767px){
  /* Tous les écrans pleine largeur sur mobile */
  .screen:not(.screen-full){left:0}

  /* Sidebar cachée hors écran par défaut */
  #bottom-nav{
    transform:translateX(-72px);
    transition:transform .25s cubic-bezier(.4,0,.2,1);
    z-index:200;
    box-shadow:none;
  }
  #bottom-nav.mobile-open{
    transform:translateX(0);
    box-shadow:6px 0 28px rgba(0,0,0,.7);
  }

  /* Bouton hamburger */
  #nav-toggle{
    display:flex;
    position:fixed;
    top:calc(14px + var(--safe-top));
    left:14px;
    z-index:150;
    width:38px;
    height:38px;
    border-radius:12px;
    background:rgba(10,10,20,.92);
    border:1px solid rgba(255,215,0,.28);
    align-items:center;
    justify-content:center;
    cursor:pointer;
    color:var(--gold);
    backdrop-filter:blur(12px);
    box-shadow:0 2px 12px rgba(0,0,0,.45);
    transition:var(--transition);
  }
  #nav-toggle:active{transform:scale(.92)}

  /* Bouton fermer dans la nav */
  #nav-close{
    display:flex;
    align-items:center;
    justify-content:center;
    width:36px;
    height:36px;
    margin:4px auto 8px;
    border-radius:10px;
    background:rgba(255,255,255,.06);
    border:1px solid var(--glass-border);
    color:var(--text3);
    cursor:pointer;
    flex-shrink:0;
    transition:var(--transition);
  }
  #nav-close:active{background:rgba(255,255,255,.12)}
}

/* ===== COLLABORATION ===== */
.collab-header{padding:calc(16px + var(--safe-top)) 20px 0;border-bottom:1px solid var(--glass-border);flex-shrink:0}
.collab-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin-bottom:4px}
.collab-sub{font-size:12px;color:var(--text3);margin-bottom:12px}
.collab-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:12px;scrollbar-width:none}
.collab-tabs::-webkit-scrollbar{display:none}
.collab-tab{flex-shrink:0;padding:8px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:var(--transition)}
.collab-tab.active{background:var(--gold-dim);border-color:rgba(255,215,0,.3);color:var(--gold)}
.collab-content{flex:1;min-height:0;overflow-y:auto;padding-bottom:calc(80px + var(--safe-bottom));-webkit-overflow-scrolling:touch}
.collab-section{padding:16px}
.collab-card{background:var(--glass);border:1px solid var(--glass-border);border-radius:16px;padding:16px;margin-bottom:12px}
.collab-card-mine{border-color:rgba(255,215,0,.3);background:rgba(255,215,0,.04)}
.collab-card-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.collab-avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#000;flex-shrink:0}
.collab-card-name{font-size:14px;font-weight:700;color:var(--text)}
.collab-card-pilier{font-size:11px;font-weight:600;margin-top:2px}
.collab-card-field{font-size:12px;color:var(--text2);line-height:1.5;margin-top:8px}
.collab-field-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:2px}
.collab-contact-btn{padding:7px 14px;background:var(--gold);color:#000;border:none;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0}
.collab-delete-btn{width:28px;height:28px;border-radius:50%;background:rgba(255,100,100,.15);border:none;color:#ff6b6b;font-size:14px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.collab-add-btn{width:100%;padding:12px;background:rgba(255,215,0,.08);border:1px dashed rgba(255,215,0,.3);border-radius:14px;color:var(--gold);font-size:13px;font-weight:700;cursor:pointer;margin-bottom:14px}
.collab-mine-badge{padding:10px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.3);border-radius:12px;color:#10b981;font-size:12px;font-weight:600;text-align:center;margin-bottom:14px}
.collab-form{background:rgba(255,255,255,.04);border:1px solid var(--glass-border);border-radius:14px;padding:16px;margin-bottom:14px}
.collab-form-title{font-size:13px;font-weight:700;color:var(--gold);margin-bottom:12px}
.collab-textarea{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--glass-border);border-radius:10px;color:var(--text);padding:10px 12px;font-size:13px;font-family:'Inter',sans-serif;resize:none;outline:none;margin-bottom:8px;box-sizing:border-box}
.collab-textarea:focus{border-color:rgba(255,215,0,.4)}
.collab-input{width:100%;background:rgba(255,255,255,.06);border:1px solid var(--glass-border);border-radius:10px;color:var(--text);padding:10px 12px;font-size:13px;outline:none;margin-bottom:8px;box-sizing:border-box}
.collab-input:focus{border-color:rgba(255,215,0,.4)}
.collab-input option{background:var(--bg2);color:var(--text)}
.collab-btn-primary{flex:1;padding:11px;background:var(--gold);color:#000;border:none;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer}
.collab-btn-ghost{padding:11px 16px;background:var(--glass);border:1px solid var(--glass-border);color:var(--text2);border-radius:12px;font-size:13px;cursor:pointer}
.collab-link-btn{display:inline-block;margin-top:10px;padding:9px 18px;background:rgba(255,215,0,.1);border:1px solid rgba(255,215,0,.3);border-radius:20px;color:var(--gold);font-size:12px;font-weight:700;text-decoration:none}
.collab-link-btn:hover{background:rgba(255,215,0,.2)}
.collab-matching-intro{background:rgba(255,215,0,.06);border:1px solid rgba(255,215,0,.15);border-radius:12px;padding:12px 14px;margin-bottom:14px}
.collab-empty{text-align:center;padding:50px 20px;color:var(--text3)}

/* ===== XAVIER ONBOARDING CHAT ===== */
#screen-xavier-onboarding{background:var(--bg);flex-direction:column;overflow:hidden}
#screen-xavier-onboarding.active{display:flex}
.xa-header{padding:calc(16px + var(--safe-top)) 20px 14px;background:var(--bg);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:12px;flex-shrink:0}
.xa-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.xa-header-info{flex:1}
.xa-header-name{font-size:14px;font-weight:700;color:var(--text)}
.xa-header-step{font-size:11px;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.xa-progress{height:2px;background:var(--bg4);border-radius:1px;margin-top:6px}
.xa-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold));border-radius:1px;transition:width .5s ease}
.xa-messages{flex:1;min-height:0;max-height:42vh;overflow-y:auto;padding:20px 16px;display:flex;flex-direction:column;gap:14px;-webkit-overflow-scrolling:touch}
.xa-bubble{max-width:85%;padding:13px 16px;border-radius:18px;font-size:14px;line-height:1.6;animation:bubbleIn .3s ease}
.xa-bubble.xavier{background:rgba(255,215,0,.07);border:1px solid rgba(255,215,0,.18);color:var(--text);align-self:flex-start;border-bottom-left-radius:5px}
.xa-bubble.user{background:rgba(255,215,0,.15);border:1px solid rgba(255,215,0,.25);color:var(--text);align-self:flex-end;border-bottom-right-radius:5px}
.xa-typing{align-self:flex-start;background:rgba(255,215,0,.07);border:1px solid rgba(255,215,0,.18);border-radius:18px;border-bottom-left-radius:5px;padding:13px 18px;display:flex;gap:5px;align-items:center}
.xa-typing span{width:7px;height:7px;border-radius:50%;background:var(--gold);display:inline-block;animation:xaDot 1.2s infinite}
.xa-typing span:nth-child(2){animation-delay:.2s}
.xa-typing span:nth-child(3){animation-delay:.4s}
@keyframes xaDot{0%,80%,100%{transform:scale(0.6);opacity:.4}40%{transform:scale(1);opacity:1}}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.xa-actions{padding:12px 16px calc(20px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:8px;flex-shrink:0;max-height:55vh;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--bg);border-top:1px solid var(--glass-border)}
.xa-options-grid{display:flex;flex-direction:column;gap:8px}
.xa-option-btn{padding:11px 16px;border:1.5px solid rgba(255,215,0,.25);border-radius:14px;background:transparent;color:var(--text);font-size:13px;font-family:'Inter',sans-serif;cursor:pointer;text-align:left;transition:.2s;line-height:1.4}
.xa-option-btn:hover,.xa-option-btn:active{background:rgba(255,215,0,.1);border-color:var(--gold)}
.xa-number-input-wrap{display:flex;flex-direction:column;gap:10px;padding:4px 0}
.xa-number-display{text-align:center;font-size:28px;font-weight:800;color:var(--gold);font-family:'DM Mono',monospace}
.xa-number-unit{font-size:13px;color:var(--text3);font-weight:400;margin-left:6px}
.xa-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg4);outline:none}
.xa-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;background:var(--gold);cursor:pointer;box-shadow:0 2px 8px rgba(255,215,0,.4)}
.xa-confirm-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#000;font-size:14px;font-weight:700;border:none;border-radius:14px;cursor:pointer;transition:.2s}
.xa-confirm-btn:hover{opacity:.9}
