*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--bg:#F7F5F2;--bg2:#EFECE8;--bg3:#E8E4DF;--card:#FFFFFF;--border:rgba(0,0,0,0.08);--border2:rgba(0,0,0,0.14);--text:#1C1917;--text2:#6B6560;--text3:#9C9892;--accent:#534AB7;--accent-l:#EEEDFE;--accent-m:#7F77DD;--sh:0 1px 3px rgba(0,0,0,0.06),0 4px 16px rgba(0,0,0,0.04);--r:16px;--rs:10px;--rx:8px;--sat:env(safe-area-inset-top,0px);--sab:env(safe-area-inset-bottom,0px)}
[data-theme="dark"]{--bg:#0F0E0D;--bg2:#1A1917;--bg3:#242220;--card:#1E1C1A;--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.12);--text:#F0EDE8;--text2:#8A8480;--text3:#5C5A56;--accent:#7F77DD;--accent-l:#1E1C3A;--accent-m:#AFA9EC}
html{font-size:16px}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased;overscroll-behavior:none}
.wrap{max-width:480px;margin:0 auto;padding:0 16px calc(80px + var(--sab))}
.hdr{position:sticky;top:0;z-index:50;background:var(--bg);padding:calc(10px + var(--sat)) 0 10px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);margin-bottom:18px;transition:background .3s}
.logo{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text);display:flex;align-items:center;gap:6px}
.logo em{color:var(--accent);font-style:normal}
.hdr-r{display:flex;align-items:center;gap:7px}
.ico-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--border2);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text2);transition:all .2s}
.ico-btn:hover{color:var(--accent);border-color:var(--accent)}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--sh);transition:background .3s,border-color .3s}
.btn-p{width:100%;padding:13px;background:var(--accent);color:#fff;border:none;border-radius:var(--rx);font-size:15px;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .2s;margin-top:3px}
.btn-p:hover{opacity:.9;transform:translateY(-1px)}
.btn-p:active{transform:translateY(0)}
.btn-p:disabled{opacity:.5;cursor:not-allowed;transform:none}
#sc-splash{position:fixed;inset:0;background:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:999;transition:opacity .45s}
#sc-splash.out{opacity:0;pointer-events:none}
.sp-logo{font-family:'DM Serif Display',serif;font-size:36px;color:#fff;letter-spacing:-.3px;margin-bottom:6px}
.sp-logo em{font-style:normal;opacity:.75}
.sp-sub{font-size:12px;color:rgba(255,255,255,.55);letter-spacing:.8px;text-transform:uppercase}
.sp-spin{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-top:36px}
@keyframes spin{to{transform:rotate(360deg)}}
#sc-auth{display:none;padding-top:10px}
.auth-hero{text-align:center;padding:26px 0 20px}
.auth-icon{width:72px;height:72px;border-radius:50%;background:var(--accent-l);border:1px solid rgba(83,74,183,.15);margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-size:30px;letter-spacing:-2px}
.auth-title{font-family:'DM Serif Display',serif;font-size:26px;line-height:1.2;color:var(--text);margin-bottom:7px}
.auth-sub{font-size:14px;color:var(--text2);line-height:1.5;max-width:290px;margin:0 auto}
.oauth-btn{width:100%;padding:12px 14px;border:1px solid var(--border2);border-radius:var(--rx);background:var(--card);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;font-size:14px;font-weight:500;font-family:'DM Sans',sans-serif;color:var(--text);margin-bottom:9px;transition:background .2s}
.oauth-btn:hover{background:var(--bg2)}
.oauth-btn:active{transform:scale(.98)}
.osv{width:20px;height:20px;flex-shrink:0}
.divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--text3);font-size:11px}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border)}
.atabs{display:flex;gap:3px;background:var(--bg2);border-radius:var(--rs);padding:3px;margin-bottom:14px;border:1px solid var(--border)}
.atab{flex:1;padding:8px;font-size:13px;font-weight:500;border:none;background:none;cursor:pointer;border-radius:7px;color:var(--text2);font-family:'DM Sans',sans-serif;transition:all .2s}
.atab.on{background:var(--card);color:var(--accent)}
.fg{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.fg label{font-size:11px;font-weight:500;color:var(--text2);letter-spacing:.3px;text-transform:uppercase}
.fg input{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--rx);padding:11px 13px;font-size:15px;font-family:'DM Sans',sans-serif;color:var(--text);outline:none;width:100%;-webkit-appearance:none;transition:border-color .2s}
.fg input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(83,74,183,.1)}
.fg input::placeholder{color:var(--text3)}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.hint{font-size:10px;color:var(--accent);font-weight:400;text-transform:none;letter-spacing:0}
.aerr{background:#FEF0F0;border:1px solid #FCA5A5;color:#991B1B;border-radius:var(--rx);padding:9px 12px;font-size:13px;margin-bottom:10px;display:none;line-height:1.4}
[data-theme="dark"] .aerr{background:#2D1515;border-color:#7F1D1D;color:#FCA5A5}
.auth-foot{text-align:center;margin-top:12px;font-size:12px;color:var(--text3)}
.auth-foot a{color:var(--accent);cursor:pointer;font-weight:500}
#sc-complete{display:none;padding-top:10px}
.notice{background:var(--accent-l);border:1px solid rgba(83,74,183,.2);border-radius:var(--rs);padding:11px 13px;margin-bottom:14px;font-size:13px;color:var(--accent);display:flex;align-items:center;gap:7px}
#sc-db{display:none}
.prof-card{background:linear-gradient(135deg,var(--accent),#3C3489);border-radius:var(--r);padding:20px;color:#fff;position:relative;overflow:hidden;margin-bottom:12px}
.prof-card::before{content:'';position:absolute;top:-30px;right:-30px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,.06)}
.prof-card::after{content:'';position:absolute;bottom:-35px;left:18px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,.04)}
.prof-top{display:flex;align-items:center;gap:13px;margin-bottom:15px;position:relative}
.sign-b{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:23px;border:1px solid rgba(255,255,255,.2);flex-shrink:0}
.pname{font-size:17px;font-weight:600;margin-bottom:2px}
.psub{font-size:11px;opacity:.7}
.pasc{font-size:10px;margin-top:4px;display:inline-flex;align-items:center;gap:3px;background:rgba(255,255,255,.15);border-radius:20px;padding:2px 7px;opacity:.9}
.pscore{margin-left:auto;text-align:right;flex-shrink:0}
.pscore-n{font-family:'DM Serif Display',serif;font-size:36px;line-height:1}
.pscore-l{font-size:9px;opacity:.6;margin-top:1px;max-width:60px;text-align:right}
.egrid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}
.ecell{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:9px;padding:8px 3px;text-align:center}
.eico{font-size:17px;line-height:1;margin-bottom:2px}
.ebar-w{width:78%;margin:3px auto;height:3px;background:rgba(255,255,255,.2);border-radius:2px;overflow:hidden}
.ebar{height:100%;border-radius:2px;background:#fff}
.elbl{font-size:8px;opacity:.65;text-transform:uppercase;letter-spacing:.3px}
.etip{font-size:8px;opacity:.7;margin-top:1px}
.tabs{display:flex;gap:3px;background:var(--bg2);border-radius:var(--rs);padding:3px;margin-bottom:10px;border:1px solid var(--border);overflow-x:auto}
.tab{flex:1;padding:8px 3px;font-size:11px;font-weight:500;border:none;background:none;cursor:pointer;border-radius:7px;color:var(--text2);transition:all .2s;text-align:center;font-family:'DM Sans',sans-serif;white-space:nowrap;min-width:48px}
.tab.on{background:var(--card);color:var(--accent)}
.view{display:none}
.view.on{display:block}
.sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.st{font-size:15px;font-weight:600;color:var(--text)}
.ss{font-size:12px;color:var(--text3)}
.vibe-g{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.vibe{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:13px;text-align:center}
.vico{font-size:25px;margin-bottom:5px}
.vlbl{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:5px}
.vmeter{width:100%;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden;margin-bottom:5px}
.vfill{height:100%;border-radius:3px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.vval{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text)}
.vhint{font-size:10px;color:var(--text3);margin-top:2px;line-height:1.3}
.planet-row{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--border)}
.planet-row:last-child{border-bottom:none;padding-bottom:0}
.psym{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.pi{flex:1}
.pn{font-size:13px;font-weight:500;color:var(--text);margin-bottom:1px}
.pd{font-size:11px;color:var(--text2)}
.pbadge{font-size:10px;font-weight:600;padding:3px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.3px}
.hm-months{display:flex;gap:2px;padding-left:44px;margin-bottom:3px}
.hm-months{display:flex;gap:3px;padding-left:44px;margin-bottom:4px}
.hm-m{font-size:9px;color:var(--text3);width:24px;text-align:center;flex-shrink:0}
.hm-row{display:flex;gap:3px;align-items:center;margin-bottom:3px}
.hm-y{font-size:10px;color:var(--text3);width:38px;text-align:right;flex-shrink:0;padding-right:4px}
.hm-cells{display:flex;gap:3px}
.hcell{width:24px;height:28px;border-radius:5px;cursor:pointer;transition:transform .12s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.hcell:hover{transform:scale(1.2)}
.hcell:active{transform:scale(0.95)}
.hm-leg{display:flex;align-items:center;gap:5px;margin-top:10px}
.hm-ld{width:11px;height:11px;border-radius:2px;flex-shrink:0}
.radar-box{position:relative;height:250px}
.house-item{display:flex;align-items:flex-start;gap:11px;padding:11px 0;border-bottom:1px solid var(--border)}
.house-item:last-child{border-bottom:none;padding-bottom:0}
.house-num{width:30px;height:30px;border-radius:50%;background:var(--accent-l);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.hi{flex:1}
.hn{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.hd{font-size:11px;color:var(--text2);line-height:1.4}
.hbar-w{height:4px;background:var(--bg3);border-radius:2px;margin-top:5px;overflow:hidden}
.hbar{height:100%;border-radius:2px;background:var(--accent)}
.period-item{display:flex;gap:10px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--border)}
.period-item:last-child{border-bottom:none;padding-bottom:0}
.pbadge2{font-size:10px;font-weight:600;padding:3px 9px;border-radius:20px;white-space:nowrap;flex-shrink:0;margin-top:1px}
.pt{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.pdc{font-size:12px;color:var(--text2);line-height:1.4}
.q-item{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px solid var(--border)}
.q-item:last-child{border-bottom:none;padding-bottom:0}
.qico{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.qname{font-size:13px;font-weight:500;color:var(--text);margin-bottom:4px}
.qbw{height:4px;background:var(--bg3);border-radius:3px;overflow:hidden}
.qb{height:100%;border-radius:3px}
.qpct{font-size:12px;font-weight:600;width:32px;text-align:right;flex-shrink:0}
.ai-card{background:linear-gradient(135deg,var(--accent-l),var(--card));border:1px solid rgba(83,74,183,.2);border-radius:var(--r);padding:17px;margin-top:11px;position:relative;overflow:hidden}
.ai-card::after{content:'✦';position:absolute;right:13px;top:11px;font-size:19px;color:var(--accent);opacity:.15}
.ai-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;color:var(--accent);background:var(--card);border:1px solid rgba(83,74,183,.2);border-radius:20px;padding:2px 9px;margin-bottom:11px;text-transform:uppercase;letter-spacing:.4px}
.ai-text{font-size:13px;line-height:1.8;color:var(--text)}
.ai-text strong{font-weight:600;color:var(--accent)}
.pulse{display:flex;gap:4px;align-items:center}
.pulse span{width:5px;height:5px;background:var(--accent);border-radius:50%;animation:dp 1.2s infinite;opacity:.4}
.pulse span:nth-child(2){animation-delay:.2s}
.pulse span:nth-child(3){animation-delay:.4s}
@keyframes dp{0%,60%,100%{opacity:.2;transform:scale(.8)}30%{opacity:1;transform:scale(1)}}
.ai-load{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:flex-end;justify-content:center;backdrop-filter:blur(3px)}
.modal-bg.open{display:flex}
.modal{background:var(--card);border-radius:22px 22px 0 0;padding:8px 20px calc(40px + var(--sab));width:100%;max-width:480px;max-height:85vh;overflow-y:auto;animation:sup .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes sup{from{transform:translateY(100%)}to{transform:translateY(0)}}
.mh{width:34px;height:3px;background:var(--bg3);border-radius:2px;margin:9px auto 16px}
.mtitle{font-family:'DM Serif Display',serif;font-size:21px;color:var(--text);margin-bottom:3px}
.msub{font-size:11px;color:var(--text2);margin-bottom:14px}
.dbar-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.dbar-l{font-size:12px;color:var(--text2);width:68px;flex-shrink:0}
.dbar-t{flex:1;height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.dbar-f{height:100%;border-radius:3px;transition:width .7s ease}
.dbar-v{font-size:12px;font-weight:600;width:26px;text-align:right;flex-shrink:0}
.toast{position:fixed;bottom:calc(70px + var(--sab));left:50%;transform:translateX(-50%) translateY(14px);background:var(--text);color:var(--bg);padding:9px 16px;border-radius:22px;font-size:13px;font-weight:500;opacity:0;transition:all .3s;pointer-events:none;white-space:nowrap;z-index:400}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.sheet-bg{position:fixed;inset:0;z-index:300;display:none;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.45);backdrop-filter:blur(4px)}
.sheet-bg.open{display:flex}
.sheet{background:var(--card);border-radius:22px 22px 0 0;padding:8px 20px calc(36px + var(--sab));width:100%;max-width:480px;animation:sup .3s cubic-bezier(.34,1.56,.64,1)}
.shandle{width:34px;height:3px;background:var(--bg3);border-radius:2px;margin:9px auto 18px}
.sacct{display:flex;align-items:center;gap:13px;padding:11px 0 14px;border-bottom:1px solid var(--border)}
.sav{width:48px;height:48px;border-radius:50%;background:var(--accent-l);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:19px;font-weight:600;flex-shrink:0}
.sname{font-size:16px;font-weight:600;color:var(--text)}
.semail{font-size:12px;color:var(--text2);margin-top:2px}
.srow{display:flex;align-items:center;gap:11px;padding:13px 0;border-bottom:1px solid var(--border);cursor:pointer}
.srow:last-child{border-bottom:none}
.srow-ico{width:34px;height:34px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.srow-lbl{font-size:14px;color:var(--text);font-weight:500}
.srow-sub{font-size:12px;color:var(--text2);margin-top:1px}
.red{color:#DC2626!important}
[data-theme="dark"] .red{color:#F87171!important}
[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1)}
[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator{filter:invert(1)}

/* Sky Chart SVG */
.sky-wheel{cursor:default}
.sky-wheel .ring{fill:none;stroke:var(--border);stroke-width:1}
.sky-wheel .sign-text{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:600;fill:var(--text);text-anchor:middle}
.sky-wheel .sign-line{stroke:var(--border);stroke-width:.5}
.sky-wheel .planet{font-family:'DM Sans',sans-serif;font-size:16px;text-anchor:middle;dominant-baseline:central;fill:var(--accent);cursor:pointer}
.sky-wheel .planet-dot{fill:var(--accent)}
.sky-wheel .aspect-line{stroke-width:1;opacity:.4}
.sky-wheel .center-text{font-family:'DM Serif Display',serif;font-size:14px;fill:var(--text);text-anchor:middle;font-style:italic}

.aspect-item{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--border)}
.aspect-item:last-child{border-bottom:none}
.aspect-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.aspect-info{flex:1;font-size:13px;color:var(--text)}
.aspect-info strong{color:var(--accent);font-weight:600}
.aspect-nat{font-size:10px;text-transform:uppercase;letter-spacing:.4px;padding:2px 7px;border-radius:20px;font-weight:600}

.elem-bar{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}
.elem-bar-lbl{width:50px;color:var(--text2)}
.elem-bar-t{flex:1;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.elem-bar-f{height:100%;border-radius:3px}
.elem-bar-v{width:24px;font-size:11px;font-weight:600;text-align:right;color:var(--text2)}

/* fu/fu2 — animations d'entrée (jouent seulement quand l'élément devient visible) */
@keyframes fadeUp { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }
.fu { animation: fadeUp .35s ease forwards; }
.fu2 { animation: fadeUp .4s .08s ease forwards; }
@media(max-width:380px){.fg2{grid-template-columns:1fr}.egrid{grid-template-columns:repeat(2,1fr)}.tab{font-size:10px}}

/* ====== TOOLTIPS ====== */
.tooltip-wrap{position:relative;display:inline-flex;align-items:center;gap:4px;cursor:help}
.tooltip-wrap .tt{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--text);color:var(--bg);font-size:11px;line-height:1.5;padding:7px 10px;border-radius:9px;white-space:normal;width:200px;text-align:center;pointer-events:none;opacity:0;transition:opacity .2s;z-index:100;font-weight:400}
.tooltip-wrap .tt::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--text)}
.tooltip-wrap:hover .tt,.tooltip-wrap:focus .tt{opacity:1}
.tt-ico{font-size:10px;opacity:.5;margin-left:2px}

/* ====== SEXUALITY TAB ====== */
.polarity-row{display:flex;gap:12px;margin-bottom:10px}
.polarity-card{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:13px;text-align:center}
.polarity-planet{font-size:28px;margin-bottom:4px}
.polarity-sign{font-family:'DM Serif Display',serif;font-size:15px;color:var(--text);margin-bottom:3px}
.polarity-role{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text3)}
.polarity-desc{font-size:11px;color:var(--text2);margin-top:6px;line-height:1.4}
.house8-row{display:flex;align-items:flex-start;gap:11px;padding:10px 0;border-bottom:1px solid var(--border)}
.house8-row:last-child{border-bottom:none}
.house8-ico{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#D4537E22,#534AB722);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.house8-lbl{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.house8-desc{font-size:11px;color:var(--text2);line-height:1.4}

/* ====== CARTE DU CIEL améliorée ====== */
.chart-planet-legend{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:12px}
.cpl-item{display:flex;align-items:center;gap:7px;background:var(--bg2);border-radius:8px;padding:7px 9px;border:1px solid var(--border)}
.cpl-sym{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.cpl-name{font-size:11px;font-weight:500;color:var(--text)}
.cpl-pos{font-size:10px;color:var(--text3);margin-top:1px}

/* ====== GLOSSAIRE ====== */
.gloss-section{}
.gloss-head{font-size:13px;font-weight:600;color:var(--accent);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.gloss-item{display:flex;gap:11px;align-items:flex-start;padding:9px 0;border-bottom:1px solid var(--border)}
.gloss-item:last-child{border-bottom:none}
.gloss-ico{width:36px;height:36px;border-radius:50%;background:var(--accent-l);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.gloss-body{flex:1}
.gloss-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}
.gloss-keyword{display:inline-block;font-size:10px;font-weight:600;color:var(--accent);background:var(--accent-l);border-radius:20px;padding:1px 8px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.4px}
.gloss-desc{font-size:12px;color:var(--text2);line-height:1.5}
.gloss-aspect-item{display:flex;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border)}
.gloss-aspect-item:last-child{border-bottom:none}
.gloss-aspect-sym{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}
.gloss-elem-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gloss-elem-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:11px}
.gloss-elem-top{display:flex;align-items:center;gap:7px;margin-bottom:5px}
.gloss-elem-ico{font-size:20px}
.gloss-elem-name{font-size:13px;font-weight:600;color:var(--text)}
.gloss-elem-signs{font-size:10px;color:var(--accent);font-weight:500;margin-bottom:3px}
.gloss-elem-desc{font-size:11px;color:var(--text2);line-height:1.4}

/* ====== UPGRADE MODAL ====== */
.upgrade-plan{background:var(--bg2);border:1px solid var(--border);border-radius:var(--rs);padding:14px;text-align:center;position:relative}
.upgrade-plan.best-value{border-color:var(--accent);background:var(--accent-l)}
.plan-best{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:9px;font-weight:700;padding:2px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.plan-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.plan-price{font-family:'DM Serif Display',serif;font-size:30px;color:var(--text);line-height:1}
.plan-period{font-size:10px;color:var(--text3);margin-top:2px}
.upgrade-feature{display:flex;align-items:center;gap:8px;padding:5px 0;font-size:13px;color:var(--text)}
.upgrade-feature-ico{color:#1D9E75;font-size:14px;flex-shrink:0}

/* ============================================
   AMÉLIORATIONS UX / ACCESSIBILITÉ
   ============================================ */

/* Focus visible pour accessibilité clavier */
button:focus-visible, input:focus-visible, [onclick]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Touch feedback amélioré sur mobile */
.tab, .ico-btn, .btn-p, .oauth-btn, .srow, .planet-row, .q-item, .house-item, .vibe, .hcell {
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

/* Animation d'entrée des cards — seulement si pas déjà animées par .fu/.fu2 */
.card:not(.fu):not(.fu2), .ai-card:not(.fu):not(.fu2) { animation: fadeSlideUp .3s ease forwards; }
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Skeleton loading pour les éléments qui chargent */
.skeleton {
  background: linear-gradient(90deg, var(--bg2) 25%, var(--bg3) 50%, var(--bg2) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 6px;
  min-height: 14px;
}
@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Indicateur de clic sur les éléments cliquables */
.planet-row:active, .q-item:active, .house-item:active, .vibe:active {
  transform: scale(0.98);
  transition: transform .1s;
}

/* Meilleur scroll sur iOS */
.modal, .wrap { -webkit-overflow-scrolling: touch; }

/* Datalist style (auto-suggestion villes) */
input::-webkit-calendar-picker-indicator { opacity: 0; }

/* Badge "nouveau" pour les features */
.badge-new {
  display: inline-flex;
  align-items: center;
  background: var(--accent);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 10px;
  margin-left: 4px;
  text-transform: uppercase;
  letter-spacing: .3px;
}

/* Amélioration heatmap sur petit écran */
@media (max-width: 360px) {
  .hcell { width: 20px; height: 24px; }
  .hm-m  { width: 20px; font-size: 8px; }
  .hm-months { padding-left: 38px; }
}

/* Print styles pour le futur PDF */
@media print {
  .hdr, .tabs, .ico-btn, .btn-p { display: none !important; }
  .card { box-shadow: none; border: 1px solid #ddd; }
  body  { background: #fff; color: #000; }
}
