:root{
  --navy:#2E3A87; --navy-deep:#28327A; --navy-ink:#1A1F4D;
  --lime:#6EDC2B; --lime-deep:#5BC41F;
  --bg:#F6F7FC; --card:#FFFFFF; --line:#E8EAF4;
  --muted:#6B7194; --text:#1A1F4D;
  --green:#16a34a; --red:#e23b4e; --amber:#f59e0b;
  --shadow:0 10px 30px -12px rgba(46,58,135,.25);
  --shadow-sm:0 2px 10px -4px rgba(46,58,135,.18);
  --r:18px; --r-sm:12px;
  --display:'Sora',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
}
html[dir="rtl"]{ --display:'Cairo',sans-serif; --body:'Cairo',sans-serif; }
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:var(--body);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ===== Lang selector ===== */
.lang-wrap{position:relative}
.lang-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:13px;font-weight:600;border:1px solid rgba(255,255,255,.22)}
.lang-btn.dark{background:#fff;color:var(--navy);border:1px solid var(--line)}
.lang-btn .flag{font-size:15px}
.lang-menu{position:absolute;top:calc(100% + 8px);inset-inline-end:0;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:6px;min-width:170px;z-index:120}
html[dir=rtl] .lang-menu{inset-inline-end:auto;inset-inline-start:0}
.lang-menu button{display:flex;width:100%;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--text);font-size:14px;font-weight:500}
.lang-menu button:hover{background:var(--bg)}
.lang-menu button.active{background:rgba(110,220,43,.14);color:var(--navy);font-weight:700}

/* ============ LANDING ============ */
#landing{min-height:100%}
.nav{position:sticky;top:0;z-index:100;background:rgba(46,58,135,.96);backdrop-filter:blur(10px)}
.nav-in{max-width:1180px;margin:0 auto;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.nav-logo img{height:34px}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{color:rgba(255,255,255,.82);font-size:14.5px;font-weight:500}
.nav-links a:hover{color:#fff}
.nav-cta{display:flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-family:var(--display);border-radius:12px;transition:transform .15s,box-shadow .15s,background .15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-lime{background:var(--lime);color:var(--navy-ink);padding:11px 20px;box-shadow:0 8px 20px -8px rgba(110,220,43,.7)}
.btn-lime:hover{background:var(--lime-deep)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;padding:11px 18px;border:1px solid rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.18)}
.btn-navy{background:var(--navy);color:#fff;padding:13px 22px}
.btn-navy:hover{background:var(--navy-deep)}
.btn-block{width:100%}
.nav-burger{display:none;font-size:24px;color:#fff}

.hero{position:relative;background:radial-gradient(120% 120% at 80% 0%,#3A47A8 0%,var(--navy) 45%,var(--navy-deep) 100%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.07) 1px,transparent 0);background-size:26px 26px;pointer-events:none}
.hero-in{max-width:1180px;margin:0 auto;padding:70px 20px 90px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(110,220,43,.16);border:1px solid rgba(110,220,43,.4);color:#cdf3b0;font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:7px 14px;border-radius:999px;margin-bottom:22px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 4px rgba(110,220,43,.25)}
h1.hero-title{font-family:var(--display);font-weight:800;font-size:clamp(34px,5vw,56px);line-height:1.05;letter-spacing:-.02em}
.hero-title .hl{color:var(--lime)}
.hero-sub{margin-top:20px;font-size:clamp(15px,1.6vw,18px);color:rgba(255,255,255,.8);max-width:520px}
.hero-actions{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{margin-top:30px;display:flex;gap:26px;flex-wrap:wrap}
.hero-trust div{display:flex;flex-direction:column}
.hero-trust b{font-family:var(--display);font-size:24px;color:#fff}
.hero-trust span{font-size:12.5px;color:rgba(255,255,255,.65)}

/* phone mockup */
.phone{justify-self:center;width:290px;height:600px;background:#0d1030;border-radius:42px;padding:12px;box-shadow:0 40px 80px -30px rgba(0,0,0,.6),0 0 0 2px rgba(255,255,255,.06);position:relative}
.phone::before{content:"";position:absolute;top:20px;left:50%;transform:translateX(-50%);width:110px;height:26px;background:#0d1030;border-radius:0 0 16px 16px;z-index:5}
.phone-screen{width:100%;height:100%;background:var(--bg);border-radius:32px;overflow:hidden;position:relative}
.pm-top{background:var(--navy);color:#fff;padding:30px 16px 16px}
.pm-bk{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);width:fit-content;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;margin-bottom:14px}
.pm-bal-l{font-size:11px;color:rgba(255,255,255,.7)}
.pm-bal{font-family:var(--display);font-size:30px;font-weight:800;margin-top:2px}
.pm-row{display:flex;gap:8px;margin-top:14px}
.pm-pill{flex:1;background:rgba(255,255,255,.1);border-radius:12px;padding:9px;text-align:center;font-size:11px}
.pm-pill b{display:block;font-family:var(--display);font-size:14px;margin-top:2px}
.pm-pill.in b{color:var(--lime)}
.pm-body{padding:14px}
.pm-tx{display:flex;align-items:center;gap:10px;background:#fff;border-radius:12px;padding:10px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.pm-ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:15px;flex-shrink:0}
.pm-ic.in{background:rgba(22,163,74,.12)}.pm-ic.out{background:rgba(226,59,78,.1)}
.pm-tx .t{flex:1;min-width:0}
.pm-tx .t b{font-size:12.5px;display:block;color:var(--navy-ink)}
.pm-tx .t span{font-size:10.5px;color:var(--muted)}
.pm-tx .amt{font-family:var(--display);font-weight:700;font-size:12.5px}
.pm-tx .amt.in{color:var(--green)}.pm-tx .amt.out{color:var(--red)}
.pm-sync{position:absolute;bottom:14px;left:14px;right:14px;background:var(--navy-ink);color:#fff;border-radius:12px;padding:9px 12px;display:flex;align-items:center;gap:8px;font-size:11px}
.pm-sync .ld{width:8px;height:8px;border-radius:50%;background:var(--lime);animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* sections */
.section{max-width:1180px;margin:0 auto;padding:80px 20px}
.sec-head{text-align:center;max-width:660px;margin:0 auto 50px}
.sec-tag{font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--lime-deep)}
.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(26px,3.4vw,38px);letter-spacing:-.02em;margin-top:10px;color:var(--navy-ink)}
.sec-head p{margin-top:14px;color:var(--muted);font-size:16px}

.books{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.book-card{border-radius:24px;padding:32px;color:#fff;position:relative;overflow:hidden;min-height:230px}
.book-card.personal{background:linear-gradient(145deg,#3A47A8,var(--navy-deep))}
.book-card.business{background:linear-gradient(145deg,#1A1F4D,#2E3A87)}
.book-card .bk-ic{font-size:30px;margin-bottom:16px}
.book-card h3{font-family:var(--display);font-size:22px;font-weight:700}
.book-card p{margin-top:10px;color:rgba(255,255,255,.78);font-size:14.5px}
.book-card ul{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px}
.book-card li{list-style:none;font-size:12.5px;background:rgba(255,255,255,.12);padding:5px 11px;border-radius:999px}
.book-card .ring{position:absolute;inset-inline-end:-40px;top:-40px;width:150px;height:150px;border:18px solid rgba(110,220,43,.18);border-radius:50%}

.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:transform .18s,box-shadow .18s}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat .fic{width:48px;height:48px;border-radius:14px;background:rgba(46,58,135,.08);display:grid;place-items:center;font-size:22px;margin-bottom:16px}
.feat h4{font-family:var(--display);font-size:17px;font-weight:700;color:var(--navy-ink)}
.feat p{margin-top:8px;color:var(--muted);font-size:14px}

.kpi-band{background:var(--navy);border-radius:28px;padding:48px 40px;color:#fff;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.kpi-band h2{font-family:var(--display);font-size:clamp(24px,3vw,32px);font-weight:800;letter-spacing:-.02em}
.kpi-band p{margin-top:14px;color:rgba(255,255,255,.78)}
.kpi-list{display:grid;gap:12px}
.kpi-item{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px 16px}
.kpi-item .k{width:38px;height:38px;border-radius:10px;background:rgba(110,220,43,.18);display:grid;place-items:center;font-size:18px}
.kpi-item b{font-family:var(--display);font-size:14.5px}
.kpi-item span{display:block;font-size:12px;color:rgba(255,255,255,.6)}

.offline-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:10px}
.off-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;text-align:center}
.off-card .o{font-size:26px}
.off-card b{display:block;font-family:var(--display);font-size:14px;margin-top:8px;color:var(--navy-ink)}

.cta-band{text-align:center;background:linear-gradient(135deg,var(--lime),var(--lime-deep));border-radius:28px;padding:56px 30px;color:var(--navy-ink)}
.cta-band h2{font-family:var(--display);font-size:clamp(26px,3.4vw,38px);font-weight:800;letter-spacing:-.02em}
.cta-band p{margin-top:12px;font-size:16px;opacity:.85;max-width:480px;margin-inline:auto}
.cta-band .btn{margin-top:26px}

footer{background:var(--navy-ink);color:rgba(255,255,255,.7);padding:50px 20px 30px}
.foot-in{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.foot-in img{height:30px;margin-bottom:14px}
.foot-col h5{color:#fff;font-family:var(--display);font-size:14px;margin-bottom:14px}
.foot-col a{display:block;font-size:13.5px;margin-bottom:10px;color:rgba(255,255,255,.65)}
.foot-col a:hover{color:var(--lime)}
.foot-bottom{max-width:1180px;margin:30px auto 0;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ============ AUTH (app.fintello.io/login) ============ */
#auth{min-height:100%;display:none;grid-template-columns:1fr 1fr}
.auth-side{background:#1a2050 center/cover no-repeat;background-image:url(../assets/auth-bg.jpg);color:#fff;padding:50px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.as-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(46,58,135,.82),rgba(26,31,77,.9) 60%,rgba(20,24,60,.94));z-index:1}
.auth-side::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0);background-size:24px 24px;z-index:1}
.auth-side img{height:78px;width:auto;max-width:400px;align-self:center;object-fit:contain;position:relative;z-index:2}
.auth-side .as-mid{position:relative;z-index:2}
.auth-side h2{font-family:var(--display);font-size:34px;font-weight:800;line-height:1.1;letter-spacing:-.02em}
.auth-side p{margin-top:16px;color:rgba(255,255,255,.78);max-width:380px}
.auth-side .as-feat{margin-top:26px;display:grid;gap:12px}
.auth-side .as-feat div{display:flex;gap:10px;align-items:center;font-size:14.5px;color:rgba(255,255,255,.9)}
.auth-side .as-feat .c{width:22px;height:22px;border-radius:50%;background:var(--lime);color:var(--navy-ink);display:grid;place-items:center;font-size:12px;font-weight:800}
.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 24px;position:relative}
.auth-lang{position:absolute;top:22px;inset-inline-end:22px}
.auth-card{width:100%;max-width:400px}
.auth-back{display:inline-flex;align-items:center;gap:4px;font-size:13.5px;font-weight:600;color:var(--muted);margin-bottom:14px}
.auth-back:hover{color:var(--navy)}
.auth-card .mob-logo{display:none}
.auth-card h3{font-family:var(--display);font-size:26px;font-weight:800;color:var(--navy-ink)}
.auth-card .sub{color:var(--muted);margin-top:6px;font-size:14.5px}
.tabs{display:flex;background:var(--bg);border-radius:12px;padding:4px;margin:24px 0}
.tabs button{flex:1;padding:10px;border-radius:9px;font-weight:600;font-size:14px;color:var(--muted)}
.tabs button.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:7px;color:var(--navy-ink)}
.field input{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;font-family:var(--body);background:#fff;transition:border .15s}
.field input:focus{outline:none;border-color:var(--navy)}
.auth-card .btn{margin-top:6px}
.auth-or{text-align:center;color:var(--muted);font-size:13px;margin:18px 0;position:relative}
.auth-or::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--line)}
.auth-or span{background:#fff;padding:0 14px;position:relative}
.book-choose{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:6px}
.bc{border:1.5px solid var(--line);border-radius:14px;padding:16px;text-align:center;transition:all .15s}
.bc:hover{border-color:var(--navy);background:var(--bg)}
.bc .e{font-size:26px}.bc b{display:block;font-family:var(--display);font-size:14px;margin-top:6px;color:var(--navy-ink)}
.auth-foot{margin-top:22px;font-size:13px;color:var(--muted);text-align:center}
.auth-foot a{color:var(--navy);font-weight:600}

/* ============ APP (app.fintello.io) ============ */
#app{display:none;min-height:100%;background:var(--bg);padding-bottom:84px;max-width:520px;margin:0 auto;position:relative;box-shadow:0 0 60px -20px rgba(46,58,135,.25);min-height:100vh}
.app-top{background:var(--navy);color:#fff;padding:calc(env(safe-area-inset-top) + 16px) 18px 18px;position:sticky;top:0;z-index:50}
.at-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.bk-switch{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);padding:8px 14px;border-radius:999px;font-weight:600;font-size:14px}
.bk-switch .bk-ic{font-size:16px}
.at-icons{display:flex;align-items:center;gap:8px}
.at-ic{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;font-size:17px}
.sync-pill{display:inline-flex;align-items:center;gap:7px;font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:999px;margin-top:14px}
.sync-pill.online{background:rgba(110,220,43,.2);color:#d6f5bf}
.sync-pill.offline{background:rgba(245,158,11,.22);color:#ffe2a8}
.sync-pill .d{width:7px;height:7px;border-radius:50%}
.sync-pill.online .d{background:var(--lime)}
.sync-pill.offline .d{background:var(--amber)}

.balance-card{margin:16px;background:linear-gradient(140deg,#3A47A8,var(--navy-deep));border-radius:22px;padding:22px;color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden}
.balance-card .ring{position:absolute;inset-inline-end:-30px;top:-30px;width:120px;height:120px;border:16px solid rgba(110,220,43,.16);border-radius:50%}
.balance-card .bl{font-size:13px;color:rgba(255,255,255,.7)}
.balance-card .bv{font-family:var(--display);font-size:34px;font-weight:800;margin-top:4px;letter-spacing:-.01em}
.bc-row{display:flex;gap:10px;margin-top:18px}
.bc-stat{flex:1;background:rgba(255,255,255,.1);border-radius:14px;padding:12px}
.bc-stat .l{font-size:11px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:5px}
.bc-stat .v{font-family:var(--display);font-weight:700;font-size:16px;margin-top:3px}
.bc-stat.in .v{color:var(--lime)}

.quick{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:0 16px 16px}
.q-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;border-radius:16px;font-family:var(--display);font-weight:700;font-size:15px;box-shadow:var(--shadow-sm)}
.q-in{background:var(--lime);color:var(--navy-ink)}
.q-out{background:#fff;color:var(--red);border:1.5px solid #ffd9de}

.app-sec{margin:0 16px 18px}
.app-sec-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.app-sec-h h3{font-family:var(--display);font-size:16px;font-weight:700;color:var(--navy-ink)}
.app-sec-h a{font-size:13px;color:var(--navy);font-weight:600}
.tx{display:flex;align-items:center;gap:12px;background:#fff;border-radius:14px;padding:12px 14px;margin-bottom:9px;box-shadow:var(--shadow-sm)}
.tx .tic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:18px;flex-shrink:0}
.tx .tic.in{background:rgba(22,163,74,.12)}.tx .tic.out{background:rgba(226,59,78,.1)}
.tx .info{flex:1;min-width:0}
.tx .info b{font-size:14.5px;display:block}
.tx .info span{font-size:12px;color:var(--muted)}
.tx .right{text-align:end}
.tx .amt{font-family:var(--display);font-weight:700;font-size:15px}
.tx .amt.in{color:var(--green)}.tx .amt.out{color:var(--red)}
.tx .badge{font-size:9.5px;font-weight:700;color:var(--amber);background:rgba(245,158,11,.14);padding:2px 6px;border-radius:6px;margin-top:3px;display:inline-block}
.empty{text-align:center;padding:30px;color:var(--muted);font-size:14px}

.cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mini{background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow-sm)}
.mini .mi{font-size:20px;margin-bottom:8px}
.mini .ml{font-size:12px;color:var(--muted)}
.mini .mv{font-family:var(--display);font-weight:700;font-size:19px;color:var(--navy-ink);margin-top:2px}

/* report screen */
.report-block{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow-sm);margin-bottom:14px}
.report-block h4{font-family:var(--display);font-size:15px;color:var(--navy-ink);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.rl{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}
.rl:last-child{border-bottom:none}
.rl.total{font-family:var(--display);font-weight:800;color:var(--navy-ink);border-top:2px solid var(--navy);margin-top:6px;padding-top:12px}
.rl .v{font-family:var(--display);font-weight:600}
.rl .v.pos{color:var(--green)}.rl .v.neg{color:var(--red)}
.profit-flag{border-radius:16px;padding:18px;text-align:center;color:#fff;margin-bottom:14px}
.profit-flag.good{background:linear-gradient(135deg,var(--green),#15803d)}
.profit-flag.bad{background:linear-gradient(135deg,var(--red),#b91c1c)}
.profit-flag .pf-l{font-size:13px;opacity:.85}
.profit-flag .pf-v{font-family:var(--display);font-size:30px;font-weight:800;margin:4px 0}
.profit-flag .pf-t{font-size:13px;font-weight:600}

/* bottom nav */
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;background:#fff;border-top:1px solid var(--line);display:flex;justify-content:space-around;padding:8px 6px calc(env(safe-area-inset-bottom) + 8px);z-index:60}
.bnav button{display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;color:var(--muted);font-weight:600;padding:4px 10px;border-radius:12px;flex:1}
.bnav button .bi{font-size:21px}
.bnav button.active{color:var(--navy)}
.bnav button.active .bi{transform:scale(1.05)}

/* FAB add (center) */
.fab{width:54px;height:54px;border-radius:50%;background:var(--lime);color:var(--navy-ink);display:grid;place-items:center;font-size:28px;font-weight:300;box-shadow:0 8px 20px -6px rgba(110,220,43,.7);margin-top:-22px}

/* sheet (modals) */
.sheet-bg{position:fixed;inset:0;background:rgba(26,31,77,.55);z-index:200;display:none;align-items:flex-end;justify-content:center}
.sheet-bg.open{display:flex}
.sheet{background:#fff;width:100%;max-width:520px;border-radius:24px 24px 0 0;padding:22px 20px calc(env(safe-area-inset-bottom) + 24px);animation:up .25s ease}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
.sheet-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.sheet-h h3{font-family:var(--display);font-size:19px;color:var(--navy-ink)}
.sheet-h button{font-size:24px;color:var(--muted)}
.seg{display:flex;background:var(--bg);border-radius:12px;padding:4px;margin-bottom:18px}
.seg button{flex:1;padding:11px;border-radius:9px;font-weight:700;font-size:14px;color:var(--muted)}
.seg button.in.on{background:var(--lime);color:var(--navy-ink)}
.seg button.out.on{background:var(--red);color:#fff}
.amt-input{display:flex;align-items:center;background:var(--bg);border-radius:16px;padding:16px;margin-bottom:16px}
.amt-input span{font-family:var(--display);font-weight:700;color:var(--muted);font-size:20px}
.amt-input input{flex:1;border:none;background:none;font-family:var(--display);font-weight:800;font-size:30px;color:var(--navy-ink);text-align:end;outline:none;width:100%}
.cat-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{padding:9px 14px;border-radius:999px;background:var(--bg);font-size:13px;font-weight:600;color:var(--muted);border:1.5px solid transparent}
.chip.on{background:rgba(46,58,135,.1);color:var(--navy);border-color:var(--navy)}

/* book switch sheet */
.bk-opt{display:flex;align-items:center;gap:14px;padding:16px;border-radius:16px;border:1.5px solid var(--line);margin-bottom:10px}
.bk-opt.on{border-color:var(--navy);background:var(--bg)}
.bk-opt .e{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:rgba(46,58,135,.08)}
.bk-opt b{font-family:var(--display);font-size:15px;color:var(--navy-ink)}
.bk-opt span{font-size:12.5px;color:var(--muted)}

/* toast */
.toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:var(--navy-ink);color:#fff;padding:12px 20px;border-radius:14px;font-size:14px;font-weight:600;z-index:300;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow);opacity:0;transition:opacity .25s,transform .25s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-6px)}

/* responsive */
@media(max-width:880px){
  .hero-in{grid-template-columns:1fr;text-align:center}
  .eyebrow,.hero-actions{justify-content:center}
  .hero-sub{margin-inline:auto}
  .hero-trust{justify-content:center}
  .phone{display:none}
  .nav-links{display:none}
  .books,.feats,.kpi-band,.offline-row,.foot-in{grid-template-columns:1fr}
  .feats{grid-template-columns:1fr 1fr}
  .offline-row{grid-template-columns:1fr 1fr}
  #auth{grid-template-columns:1fr}
  .auth-side{display:none}
  .auth-card .mob-logo{display:block;height:60px;width:auto;max-width:120px;object-fit:contain;margin:0 auto 26px}
}
@media(max-width:520px){
  .feats{grid-template-columns:1fr}
  .nav-cta .btn-ghost{display:none}
}

/* ===== NEW AUTH ===== */
.as-eyebrow{font-family:var(--display);font-weight:700;font-size:12px;letter-spacing:.18em;color:var(--lime);margin-bottom:14px}
.as-steps{margin-top:24px;display:grid;gap:18px}
.as-step{display:flex;gap:14px;align-items:flex-start}
.as-step .n{width:30px;height:30px;border-radius:50%;background:rgba(110,220,43,.2);border:1.5px solid var(--lime);color:var(--lime);font-family:var(--display);font-weight:800;font-size:14px;display:grid;place-items:center;flex-shrink:0}
.as-step b{font-family:var(--display);font-size:15.5px;color:#fff}
.as-step p{font-size:13px;color:rgba(255,255,255,.72);margin-top:3px}
.as-secure{position:relative;z-index:2;font-size:12.5px;color:rgba(255,255,255,.72);text-align:center}
.auth-eyebrow{font-family:var(--display);font-weight:700;font-size:11px;letter-spacing:.16em;color:var(--lime-deep)}
.auth-card h3{margin-top:6px}
.req{color:var(--lime-deep)}
.select-wrap{position:relative}
.select-wrap::after{content:"▾";position:absolute;inset-inline-end:14px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.select-wrap select{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;font-family:var(--body);background:#fff;appearance:none;color:var(--text)}
.select-wrap select:focus{outline:none;border-color:var(--navy)}
.phone-field{display:flex;align-items:stretch;border:1.5px solid var(--line);border-radius:12px;overflow:hidden}
.phone-field:focus-within{border-color:var(--navy)}
.phone-field .dial{display:flex;align-items:center;padding:0 14px;background:var(--bg);font-weight:700;font-family:var(--display);color:var(--navy);font-size:15px;border-inline-end:1.5px solid var(--line)}
.phone-field input{flex:1;border:none;padding:13px 14px;font-size:15px;font-family:var(--body);outline:none;background:#fff;width:100%}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.pin-input{letter-spacing:.5em;font-family:var(--display);font-weight:700;font-size:18px}
.pin-forgot{float:inline-end;font-size:12px;color:var(--navy);font-weight:600}
html[dir=rtl] .pin-forgot{float:left}
.btn-arrow{font-size:15.5px}

/* ===== PARTIES (Carnet) ===== */
.seg2{display:flex;background:var(--navy);padding:0 16px;gap:0}
.seg2 button{flex:1;padding:14px 0;font-weight:700;font-size:14.5px;color:rgba(255,255,255,.6);border-bottom:3px solid transparent;font-family:var(--display)}
.seg2 button.on{color:#fff;border-color:var(--lime)}
.party-totals{display:flex;gap:12px;padding:16px}
.pt-box{flex:1;border-radius:16px;padding:14px;box-shadow:var(--shadow-sm)}
.pt-box.get{background:rgba(22,163,74,.1)}
.pt-box.give{background:rgba(226,59,78,.08)}
.pt-box .l{font-size:12px;color:var(--muted);font-weight:600}
.pt-box .v{font-family:var(--display);font-weight:800;font-size:19px;margin-top:3px}
.pt-box.get .v{color:var(--green)}
.pt-box.give .v{color:var(--red)}
.search-bar{display:flex;align-items:center;gap:8px;margin:0 16px;background:#fff;border:1.5px solid var(--line);border-radius:12px;padding:10px 14px}
.search-bar input{flex:1;border:none;outline:none;font-size:14.5px;font-family:var(--body);background:none}
.party{display:flex;align-items:center;gap:12px;background:#fff;border-radius:14px;padding:12px 14px;margin-bottom:9px;box-shadow:var(--shadow-sm)}
.party .pav{width:44px;height:44px;border-radius:12px;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:17px;flex-shrink:0}
.party .pinfo{flex:1;min-width:0}
.party .pinfo b{font-size:15px;display:block}
.party .pinfo span{font-size:12px;color:var(--muted)}
.party .pamt{text-align:end}
.party .pamt .a{font-family:var(--display);font-weight:700;font-size:15px}
.party .pamt .a.get{color:var(--green)}
.party .pamt .a.give{color:var(--red)}
.party .pamt .s{font-size:10.5px;color:var(--muted)}

/* ===== PARTY DETAIL ===== */
.pd-head{background:var(--navy);color:#fff;display:flex;align-items:center;gap:12px;padding:14px 16px}
.pd-head .back{font-size:28px;color:#fff;line-height:1}
.pd-av{width:42px;height:42px;border-radius:12px;background:rgba(255,255,255,.15);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:17px}
.pd-name b{font-family:var(--display);font-size:16px;display:block}
.pd-name span{font-size:12px;color:rgba(255,255,255,.7)}
.pd-balance{margin:16px;border-radius:18px;padding:18px;text-align:center;box-shadow:var(--shadow-sm);background:rgba(22,163,74,.08)}
.pd-balance.give{background:rgba(226,59,78,.07)}
.pd-balance .l{font-size:13px;color:var(--muted);font-weight:600}
.pd-balance .v{font-family:var(--display);font-weight:800;font-size:30px;margin:4px 0;color:var(--green)}
.pd-balance.give .v{color:var(--red)}
.pd-actions{display:flex;gap:10px;justify-content:center;margin-top:8px}
.pd-actions button{font-size:12.5px;font-weight:600;color:var(--navy);background:#fff;border:1.5px solid var(--line);padding:8px 14px;border-radius:999px}
.entries-head{display:flex;justify-content:space-between;padding:0 18px 6px;font-size:12px;color:var(--muted);font-weight:600}
.entry{display:flex;align-items:center;background:#fff;border-radius:12px;padding:12px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.entry .ed{flex:1}
.entry .ed b{font-size:13.5px}
.entry .ed span{font-size:11px;color:var(--muted);display:block}
.entry .col{width:90px;text-align:end;font-family:var(--display);font-weight:700;font-size:14px}
.entry .give-c{color:var(--red)}
.entry .get-c{color:var(--green)}
.pd-foot{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:520px;display:flex;gap:10px;padding:12px 16px calc(env(safe-area-inset-bottom) + 12px);background:#fff;border-top:1px solid var(--line);z-index:60}
.pd-foot button{flex:1;padding:14px;border-radius:14px;font-family:var(--display);font-weight:700;font-size:14px}
.pd-give{background:#fff;color:var(--red);border:1.5px solid #ffd9de}
.pd-get{background:var(--lime);color:var(--navy-ink)}

/* ===== ITEMS ===== */
.stock-total{font-size:12px;color:var(--muted)}
.stock-banner{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#3A47A8,var(--navy-deep));color:#fff;border-radius:16px;padding:16px;margin-bottom:14px}
.stock-banner b{font-family:var(--display);font-size:20px}
.item-row{display:flex;align-items:center;gap:12px;background:#fff;border-radius:14px;padding:12px 14px;margin-bottom:9px;box-shadow:var(--shadow-sm)}
.item-row .iic{width:42px;height:42px;border-radius:12px;background:rgba(46,58,135,.08);display:grid;place-items:center;font-size:19px}
.item-row .iinfo{flex:1}
.item-row .iinfo b{font-size:14.5px;display:block}
.item-row .iinfo span{font-size:12px;color:var(--muted)}
.item-row .iright{text-align:end}
.item-row .iright b{font-family:var(--display);font-size:14.5px;color:var(--navy)}
.item-row .iright .stk{font-size:11px;font-weight:700;padding:2px 7px;border-radius:6px;background:rgba(22,163,74,.12);color:var(--green);display:inline-block;margin-top:3px}
.item-row .iright .stk.low{background:rgba(245,158,11,.16);color:var(--amber)}

/* ===== SETTINGS ===== */
.set-profile{display:flex;align-items:center;gap:14px;background:#fff;border-radius:16px;padding:16px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.set-profile .sp-av{width:50px;height:50px;border-radius:14px;background:var(--navy);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:19px}
.set-profile b{font-family:var(--display);font-size:16px;color:var(--navy-ink)}
.set-profile span{font-size:13px;color:var(--muted);display:block}
.set-group{background:#fff;border-radius:16px;box-shadow:var(--shadow-sm);margin-bottom:16px;overflow:hidden}
.set-row{display:flex;align-items:center;gap:14px;padding:15px 16px;border-bottom:1px solid var(--line)}
.set-row:last-child{border-bottom:none}
.set-row .si{font-size:20px}
.set-row .st{flex:1}
.set-row .st b{font-size:14.5px;display:block;color:var(--navy-ink)}
.set-row .st span{font-size:12px;color:var(--muted)}
.set-row .sv{font-size:14px;color:var(--muted);font-weight:600}
.set-row .sv b{color:var(--navy)}

/* ===== sheets extra ===== */
.seg2-mini{display:flex;background:var(--bg);border-radius:12px;padding:4px;margin-bottom:16px}
.add-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ag{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;border-radius:16px;border:1.5px solid var(--line);background:#fff}
.ag .e{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;font-size:22px;font-weight:300;background:rgba(46,58,135,.08);color:var(--navy)}
.ag .e.in{background:rgba(110,220,43,.18);color:var(--lime-deep)}
.ag .e.out{background:rgba(226,59,78,.1);color:var(--red)}
.ag b{font-family:var(--display);font-size:13.5px;color:var(--navy-ink)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid2 .field{margin-bottom:16px}
.xe-note{background:rgba(110,220,43,.12);border-radius:12px;padding:12px 14px;font-size:13px;color:var(--navy-ink);margin-bottom:14px}
.cur-list{display:grid;gap:8px;max-height:50vh;overflow:auto}
.cur-opt{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:12px;border:1.5px solid var(--line)}
.cur-opt.on{border-color:var(--navy);background:var(--bg)}
.cur-opt .csym{width:40px;height:40px;border-radius:10px;background:rgba(46,58,135,.08);display:grid;place-items:center;font-family:var(--display);font-weight:700;color:var(--navy)}
.cur-opt b{font-size:14px;color:var(--navy-ink)}
.cur-opt span{font-size:12px;color:var(--muted);display:block}
/* ====== Auth refonte (v1.9) ====== */
.auth-head{text-align:center;margin-bottom:4px}
.auth-card .auth-head .sub{margin-left:auto;margin-right:auto;max-width:340px}
/* curseur pointeur sur tous les éléments cliquables */
button,.tabs button,.seg2 button,.lang-btn,.lang-menu button,.auth-foot a,.pin-forgot,.dial,.btn-otp,a[onclick],[onclick]{cursor:pointer}
/* segmented control (phone/email, password/otp) */
.seg-pill{display:flex;background:var(--bg);border-radius:12px;padding:4px;margin:0 0 16px;gap:4px}
.seg-pill button{flex:1;padding:9px;border-radius:9px;font-weight:600;font-size:13.5px;color:var(--muted);background:transparent;border:none}
.seg-pill button.active{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
/* dial code selector */
.phone-field .dial{display:flex;align-items:center;gap:5px;padding:0 12px;background:var(--bg);font-weight:700;font-family:var(--display);color:var(--navy);font-size:14.5px;border:none;border-inline-end:1.5px solid var(--line);white-space:nowrap}
.dial-caret{font-size:11px;color:var(--muted)}
.dial-menu{position:absolute;z-index:140;margin-top:6px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);padding:8px;width:300px;max-width:88vw;max-height:300px;overflow:auto}
.dial-menu .dm-search{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:14px;margin-bottom:6px;font-family:var(--body)}
.dial-menu .dm-search:focus{outline:none;border-color:var(--navy)}
.dial-menu button{display:flex;width:100%;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-radius:10px;color:var(--text);font-size:14px;font-weight:500;background:transparent;border:none;text-align:start}
.dial-menu button:hover{background:var(--bg)}
.dial-menu button .dm-dial{font-weight:700;color:var(--navy);font-family:var(--display)}
/* OTP field + send button */
.otp-field{display:flex;gap:8px;align-items:stretch}
.otp-field .pin-input{flex:1}
.btn-otp{flex:0 0 auto;padding:0 14px;border-radius:12px;background:var(--navy);color:#fff;font-weight:700;font-size:13.5px;border:none;white-space:nowrap}
.btn-otp:hover{background:var(--navy-deep)}
.btn-otp:disabled{opacity:.55;cursor:default}

/* état vide listes (inventaire) */
.empty-hint{text-align:center;color:var(--muted);font-size:14px;padding:34px 12px}

/* =========================================================
   ===========  APP — REFONTE STYLE KHATABOOK  ============
   ========================================================= */

/* Sélecteur de langue bien visible sur la page de connexion (fond blanc) */
.auth-lang .lang-btn{background:#fff;color:var(--navy);border:1.5px solid var(--line);box-shadow:var(--shadow-sm)}
.auth-lang .lang-btn:hover{border-color:var(--navy)}
@media(max-width:880px){ .auth-lang{top:16px;inset-inline-end:16px} }

/* Conteneur app : pleine largeur (plus de colonne 520px) */
#app{display:none;min-height:100vh;max-width:none;margin:0;box-shadow:none;background:var(--bg);padding-bottom:0}
.app-shell{display:flex;min-height:100vh}

/* ---- Barre du haut (mobile) ---- */
.m-topbar{display:none;align-items:center;gap:12px;background:var(--navy);color:#fff;padding:calc(env(safe-area-inset-top) + 12px) 16px 12px;position:sticky;top:0;z-index:80}
.m-topbar .m-burger{font-size:24px;color:#fff;line-height:1;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.12)}
.m-topbar .m-logo{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);height:38px;width:auto;max-width:60vw;object-fit:contain}
.m-topbar .lang-wrap{margin-inline-start:auto}

/* ---- Sidebar gauche ---- */
.sidebar{width:248px;flex-shrink:0;background:linear-gradient(180deg,#2E3A87,#222a6b);color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;z-index:90}
.sb-brand{padding:22px 20px 14px;display:flex;justify-content:center;align-items:center}
.sb-brand img{height:46px;width:auto;max-width:230px;object-fit:contain}
.sb-book{display:flex;align-items:center;gap:11px;margin:0 14px 8px;padding:11px 12px;border-radius:14px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);width:calc(100% - 28px);text-align:start}
.sb-book:hover{background:rgba(255,255,255,.14)}
.sb-book .sbb-av{width:38px;height:38px;border-radius:11px;background:var(--lime);color:var(--navy-ink);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:15px;flex-shrink:0}
.sb-book .sbb-txt{flex:1;min-width:0}
.sb-book .sbb-txt b{font-family:var(--display);font-size:14px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-book .sbb-txt small{font-size:11px;color:rgba(255,255,255,.7);display:flex;align-items:center;gap:5px}
.sb-book .dot-on{width:7px;height:7px;border-radius:50%;background:var(--lime);display:inline-block}
.sb-book .sbb-caret{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.65);flex-shrink:0}
.sb-book .sbb-caret svg{display:block}
.sb-book:hover .sbb-caret{color:rgba(255,255,255,.95)}
.sb-nav{flex:1;padding:6px 12px 12px;display:flex;flex-direction:column;gap:2px}
.sb-sec{font-size:10.5px;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.42);padding:14px 12px 6px}
.sb-link{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:11px;color:rgba(255,255,255,.82);font-size:14px;font-weight:600;width:100%;text-align:start;border-inline-start:3px solid transparent}
.sb-link .ic{font-size:17px;width:22px;text-align:center}
.sb-link:hover{background:rgba(255,255,255,.08);color:#fff}
.sb-link.active{background:rgba(255,255,255,.12);color:#fff;border-inline-start-color:var(--lime)}
.sb-foot{padding:12px 16px calc(env(safe-area-inset-bottom) + 14px);display:flex;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,.1)}
.sb-foot .lang-wrap{flex:1}
.sb-online{width:40px;height:40px;border-radius:11px;background:rgba(110,220,43,.2);color:#d6f5bf;display:grid;place-items:center;font-size:17px}
.sb-scrim{display:none;position:fixed;inset:0;background:rgba(26,31,77,.5);z-index:85}

/* ---- Zone principale ---- */
.main-area{flex:1;min-width:0;padding:22px clamp(16px,3vw,40px) 120px;max-width:1180px;margin:0 auto;width:100%}
.main-area .sync-pill{margin:0 0 14px}
.main-area .sync-pill.online{background:rgba(110,220,43,.16);color:#2f7a14}
.main-area .sync-pill.offline{background:rgba(245,158,11,.18);color:#9a5b06}
.page-h{margin:2px 0 16px}
.page-h h2{font-family:var(--display);font-weight:800;font-size:24px;color:var(--navy-ink);letter-spacing:-.01em}

/* sur desktop, on annule les marges latérales internes (gérées par main-area) */
.main-area .balance-card,
.main-area .quick,
.main-area .app-sec{margin-inline:0}
.main-area .party-totals,
.main-area .search-bar{padding-inline:0}
.main-area .seg2{border-radius:14px;padding:0 14px;margin-bottom:4px}

/* état vide (modules en préparation) */
.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:18px;box-shadow:var(--shadow-sm);margin-top:8px}
.empty-state .es-ic{font-size:46px;margin-bottom:12px}
.empty-state b{font-family:var(--display);font-size:17px;color:var(--navy-ink);display:block}
.empty-state p{color:var(--muted);font-size:14px;margin-top:6px}

/* bannière régime TVA (écran Ventes) */
.tva-banner{background:#fff;border-radius:18px;padding:20px;box-shadow:var(--shadow-sm);margin-bottom:16px}
.tva-banner .tvab-l b{font-family:var(--display);font-size:16px;color:var(--navy-ink);display:block}
.tva-banner .tvab-l span{font-size:13px;color:var(--muted)}
.tva-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.tva-opt{border:1.5px solid var(--line);border-radius:14px;padding:18px;text-align:start;transition:all .15s}
.tva-opt:hover{border-color:var(--navy);background:var(--bg)}
.tva-opt .e{font-size:24px}
.tva-opt b{display:block;font-family:var(--display);font-size:14px;color:var(--navy-ink);margin-top:8px}
.tva-opt small{font-size:12px;color:var(--muted)}

/* bloc TVA dans la feuille article */
.tva-block{border-top:1px solid var(--line);margin-top:4px;padding-top:14px}
.tva-switch{display:flex;align-items:center;justify-content:space-between;background:var(--bg);border-radius:12px;padding:12px 14px;margin-bottom:14px;font-size:14px;font-weight:600;color:var(--navy-ink)}
.tva-switch input[type=checkbox]{width:44px;height:26px;-webkit-appearance:none;appearance:none;background:var(--line);border-radius:999px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}
.tva-switch input[type=checkbox]::after{content:"";position:absolute;top:3px;inset-inline-start:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s}
.tva-switch input[type=checkbox]:checked{background:var(--lime)}
.tva-switch input[type=checkbox]:checked::after{transform:translateX(18px)}
html[dir=rtl] .tva-switch input[type=checkbox]:checked::after{transform:translateX(-18px)}

/* bouton flottant bleu : coin bas-GAUCHE (à droite de la barre latérale sur
   desktop, bord gauche sur mobile). Mêmes propriétés que le bouton vert. */
.float-add{position:fixed;bottom:24px;left:270px;z-index:70;background:var(--navy);color:#fff;font-family:var(--display);font-weight:800;font-size:15px;padding:14px 22px;border:none;border-radius:999px;box-shadow:0 10px 26px -10px rgba(46,58,135,.5);display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.float-add:hover{filter:brightness(1.03);transform:translateY(-1px)}
.float-add:active{transform:translateY(0)}
/* variante verte (boutons Budget / Objectifs / Dettes) : identique au bouton
   vert d'origine — fond lime, texte sombre — pointeur et effets hérités. */
.float-add.is-green{background:var(--lime);color:var(--navy-ink)}
.float-add.is-green:hover{filter:brightness(1.03)}

/* pied de fiche tiers : aligné sur la zone principale (desktop) */
.pd-foot{left:auto;transform:none;position:fixed;bottom:0;width:auto;max-width:none;margin:0}

/* sheets : centrées en modale sur desktop */
@media(min-width:961px){
  .sheet-bg{align-items:center}
  .sheet{max-width:460px;border-radius:22px;animation:pop .2s ease}
  @keyframes pop{from{transform:scale(.96);opacity:.6}to{transform:scale(1);opacity:1}}
  .toast{bottom:30px}
}

/* ---- Responsive : sidebar en tiroir ---- */
@media(max-width:960px){
  .m-topbar{display:flex}
  .app-shell{display:block}
  .sidebar{position:fixed;top:0;inset-inline-start:0;height:100vh;transform:translateX(-100%);transition:transform .25s ease;box-shadow:0 0 50px rgba(0,0,0,.4)}
  html[dir=rtl] .sidebar{transform:translateX(100%)}
  .sidebar.open{transform:translateX(0)}
  .sb-scrim.open{display:block}
  .main-area{padding:18px 16px 110px;max-width:640px}
  .pd-foot{left:50%;transform:translateX(-50%);width:100%;max-width:640px}
  .float-add{left:16px;bottom:18px;padding:13px 20px}
}

/* ============================================================
   v1.13 — Export PDF/Excel + Outils calculateurs + impression
   ============================================================ */
.export-bar{display:flex;align-items:center;gap:8px;margin:18px 0 8px;flex-wrap:wrap}
.export-bar .exb-l{font-size:12.5px;font-weight:700;color:var(--muted)}
.exb-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1.5px solid var(--line);color:var(--navy-ink);font-weight:700;font-size:13px;padding:8px 14px;border-radius:10px;cursor:pointer;transition:.15s}
.exb-btn:hover{border-color:var(--navy);background:var(--navy);color:#fff}
.exb-btn.sm{padding:6px 11px;font-size:12px}
.exb-inline{display:flex;gap:8px}

.calc-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;flex-direction:column;gap:14px;box-shadow:0 6px 24px -16px rgba(46,58,135,.3)}
.calc-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.calc-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.calc-field label{font-size:12.5px;font-weight:700;color:var(--navy-ink)}
.calc-field input{border:1.5px solid var(--line);border-radius:10px;padding:11px 12px;font-size:15px;font-family:inherit;width:100%;box-sizing:border-box}
.calc-field input:focus{outline:none;border-color:var(--navy)}
.calc-btn{background:var(--lime);color:var(--navy-ink);font-weight:800;font-size:15px;border:none;border-radius:12px;padding:13px;cursor:pointer;margin-top:2px}
.calc-btn:active{transform:translateY(1px)}
.calc-result{margin-top:14px;background:linear-gradient(135deg,var(--navy),#1f2a6b);border-radius:16px;padding:4px 18px;color:#fff}
.calc-result .cr-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.calc-result .cr-row:last-child{border-bottom:none}
.calc-result .cr-row span{font-size:14px;color:rgba(255,255,255,.85)}
.calc-result .cr-row b{font-size:17px;font-weight:800;text-align:right}
.calc-result .cr-row.hl b{color:var(--lime);font-size:19px}

@media print{
  .m-topbar,.sidebar,.sb-scrim,.export-bar,.float-add,.calc-btn,.bnav{display:none!important}
  .app-shell{display:block}
  .main-area{max-width:none;margin:0;padding:0}
  #app{box-shadow:none;background:#fff}
  body{background:#fff}
}

/* ============================================================
   v1.14 — œil mot de passe, langue haut-droite, nouveau livre,
   espacement switch-book, listes Revenus/Dépenses
   ============================================================ */
/* Œil mot de passe */
.pass-wrap{position:relative}
.pass-wrap input{width:100%;box-sizing:border-box;padding-inline-end:46px}
.pass-eye{position:absolute;inset-inline-end:8px;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-size:17px;background:transparent;border:none;opacity:.7;cursor:pointer}
.pass-eye:hover{opacity:1;background:var(--bg)}
html[dir=rtl] .pass-wrap input{padding-inline-end:46px}

/* Langue + statut en haut à droite de la zone principale */
.main-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.main-top .sync-pill{margin:0}
.mt-right{display:flex;align-items:center;gap:10px}
.main-top .sb-online{width:38px;height:38px;border-radius:11px;background:#fff;border:1.5px solid var(--line);color:var(--navy);display:grid;place-items:center;font-size:16px;cursor:pointer}
.main-top .sb-online:hover{border-color:var(--navy)}
.main-top .lang-btn{box-shadow:var(--shadow-sm)}

/* Switch book : espace titre / description */
.bk-opt .bk-txt{display:flex;flex-direction:column;gap:3px;min-width:0}
.bk-opt .bk-txt b{display:block;line-height:1.2}
.bk-opt .bk-txt span{display:block;line-height:1.3}
.bk-opt.bk-new{cursor:pointer}

/* Nouveau livre : sélecteur de type */
.nb-lbl{display:block;font-size:12.5px;font-weight:700;color:var(--navy-ink);margin:14px 0 8px}
.nb-types{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.nb-type{display:flex;flex-direction:column;align-items:flex-start;gap:3px;text-align:start;padding:14px;border-radius:14px;border:1.5px solid var(--line);background:#fff;cursor:pointer}
.nb-type .e{font-size:22px}
.nb-type b{font-family:var(--display);font-size:14px;color:var(--navy-ink)}
.nb-type small{font-size:11.5px;color:var(--muted);line-height:1.3}
.nb-type.on{border-color:var(--navy);background:var(--bg);box-shadow:0 0 0 3px rgba(46,58,135,.08)}

/* Listes Revenus / Dépenses */
.money-sum{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-radius:16px;margin-bottom:14px;font-weight:600}
.money-sum span{font-size:13.5px;color:var(--muted)}
.money-sum b{font-family:var(--display);font-size:22px}
.money-sum.in{background:rgba(110,220,43,.12)}
.money-sum.in b{color:#2f7a14}
.money-sum.out{background:rgba(244,63,94,.10)}
.money-sum.out b{color:#c5283d}
.money-list{display:flex;flex-direction:column;gap:2px}
.money-list .tx{cursor:pointer;border-radius:12px;padding:12px 10px;transition:background .12s}
.money-list .tx:hover{background:var(--bg)}

/* Bouton danger */
.btn-danger{background:#fff;color:#c5283d;border:1.5px solid rgba(197,40,61,.35)}
.btn-danger:hover{background:rgba(197,40,61,.06)}

/* Logo : centrage propre haut-gauche */
.auth-side img{height:82px;max-width:420px;align-self:center;margin:64px 0 0}
.sb-brand{padding:20px 20px 14px;display:flex;align-items:center;justify-content:center}
.sb-brand img{height:48px;max-width:240px}

@media(max-width:960px){
  /* sur mobile, le logo de la barre suffit : pas de doublon de langue */
  .main-top{margin-bottom:12px}
}

/* ============================================================
   v1.15 — Cashbook (Cash in/out), clavier, formulaire, déconnexion sidebar
   ============================================================ */
.cash-wrap{display:flex;gap:20px;align-items:flex-start}
.cash-main{flex:1;min-width:0}
.cash-actions{width:230px;flex-shrink:0;display:flex;flex-direction:column;gap:14px;position:sticky;top:80px}
.cash-act{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:18px;border-radius:16px;color:#fff;cursor:pointer;border:none;text-align:start;box-shadow:0 8px 24px -14px rgba(0,0,0,.4)}
.cash-act .ca-ic{font-size:22px;line-height:1}
.cash-act b{font-size:17px;font-family:var(--display)}
.cash-act small{font-size:12px;opacity:.92}
.cash-act.in{background:linear-gradient(135deg,#5bb318,#6EDC2B)}
.cash-act.in b,.cash-act.in small,.cash-act.in .ca-ic{color:#10331a}
.cash-act.out{background:linear-gradient(135deg,#c5283d,#f43f5e)}
.cash-act:active{transform:translateY(1px)}

.cash-sum{background:linear-gradient(135deg,var(--navy),#1f2a6b);color:#fff;border-radius:18px;padding:18px;margin-bottom:14px}
.cash-sum .cs-net{display:flex;flex-direction:column;gap:3px}
.cash-sum .cs-net span{font-size:13px;color:rgba(255,255,255,.8)}
.cash-sum .cs-net b{font-family:var(--display);font-size:28px}
.cash-sum .cs-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.cash-sum .cs-stat{background:rgba(255,255,255,.10);border-radius:12px;padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.cash-sum .cs-stat span{font-size:12px;color:rgba(255,255,255,.8)}
.cash-sum .cs-stat b{font-size:16px;font-weight:700}
.cash-sum .cs-stat.in b{color:#bff299}
.cash-sum .cs-stat.out b{color:#ffb3bd}

.cf-lbl{display:block;font-size:12.5px;font-weight:700;color:var(--navy-ink);margin:14px 0 6px}
.cf-inp{width:100%;box-sizing:border-box;padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:15px;font-family:inherit}
.cf-inp:focus{outline:none;border-color:var(--navy)}
.cash-amt{position:relative}
.cash-amt input{padding-inline-end:54px}
.kp-btn{position:absolute;inset-inline-end:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:10px;background:var(--bg);border:1.5px solid var(--line);font-size:18px;cursor:pointer}
.kp-btn:hover{border-color:var(--navy)}
.keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.keypad button{padding:15px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-size:20px;font-weight:700;color:var(--navy-ink);cursor:pointer}
.keypad button:active{background:var(--bg)}
.cf-upload{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 14px;border:1.5px dashed var(--line);border-radius:12px;cursor:pointer;color:var(--navy);font-weight:600;font-size:14px}
.cf-upload:hover{border-color:var(--navy)}
.cf-file{font-size:12px;color:var(--muted);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:55%}
.cash-h-in{color:#2f7a14}
.cash-h-out{color:#c5283d}

/* Déconnexion en bas de la sidebar */
.sb-foot{padding:10px 14px calc(env(safe-area-inset-bottom) + 14px);border-top:1px solid rgba(255,255,255,.12);margin-top:auto}
.sb-logout{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 14px;border-radius:12px;color:#ffb3bd;font-weight:600;font-size:14.5px;background:rgba(244,63,94,.10);border:none;cursor:pointer;text-align:center}
.sb-logout:hover{background:rgba(244,63,94,.20);color:#fff}
.sb-logout .ic{font-size:18px}

/* Pastille de comptage des alertes dans la nav */
.sb-link .sb-badge{margin-inline-start:auto;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#f43f5e;color:#fff;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;line-height:1}
.mt-spacer{flex:1}

/* ============================================================
   v1.16 — Écran Alertes
   ============================================================ */
.alerts-summary{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.al-chip{display:flex;align-items:center;gap:6px;padding:8px 12px;border-radius:12px;font-size:12.5px;font-weight:600;background:var(--bg);color:var(--muted);border:1px solid var(--line)}
.al-chip b{font-family:var(--display);font-size:16px}
.al-chip.high{background:rgba(244,63,94,.10);color:#c5283d;border-color:rgba(244,63,94,.25)}
.al-chip.med{background:rgba(245,158,11,.12);color:#9a5b06;border-color:rgba(245,158,11,.28)}
.al-chip.low{background:rgba(46,58,135,.08);color:var(--navy);border-color:rgba(46,58,135,.18)}
.alert-item{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;background:#fff;border:1px solid var(--line);border-inline-start:4px solid var(--line);margin-bottom:10px;cursor:pointer}
.alert-item:hover{box-shadow:var(--shadow-sm)}
.alert-item.high{border-inline-start-color:#f43f5e}
.alert-item.med{border-inline-start-color:var(--amber)}
.alert-item.low{border-inline-start-color:var(--navy)}
.alert-item .al-ic{font-size:22px;width:34px;text-align:center;flex-shrink:0}
.alert-item .al-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.alert-item .al-txt b{font-size:14.5px;color:var(--navy-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.alert-item .al-txt span{font-size:13px;color:var(--muted)}
.alert-item .al-go{font-size:20px;color:var(--muted);flex-shrink:0}

@media(max-width:960px){
  .cash-wrap{flex-direction:column}
  .cash-actions{width:100%;flex-direction:row;position:static}
  .cash-act{flex:1}
}

/* ============================================================
   v1.18 — Bouton rapide global + Objectifs d'épargne + Dettes
   ============================================================ */
.global-add{position:fixed;right:22px;bottom:24px;z-index:75;background:var(--red);color:#fff;font-family:var(--display);font-weight:800;font-size:15px;padding:14px 22px;border:none;border-radius:999px;box-shadow:0 10px 26px -10px rgba(46,58,135,.5);display:flex;align-items:center;gap:8px;cursor:pointer}
.global-add:hover{filter:brightness(1.03);transform:translateY(-1px)}
.global-add:active{transform:translateY(0)}
@media(max-width:960px){ .global-add{right:16px;bottom:18px;padding:13px 20px} }
@media print{ .global-add{display:none!important} }

/* Objectifs d'épargne */
.goal{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
.goal-h{display:flex;align-items:center;gap:12px;cursor:pointer}
.goal-ic{font-size:24px;width:40px;height:40px;border-radius:12px;background:var(--bg);display:grid;place-items:center;flex-shrink:0}
.goal-info{flex:1;min-width:0}
.goal-info b{display:block;font-size:15px;color:var(--navy-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.goal-info span{font-size:12.5px;color:var(--muted)}
.goal-amt{text-align:end;flex-shrink:0}
.goal-amt b{display:block;font-size:15px;color:var(--navy-ink)}
.goal-amt span{font-size:12px;color:var(--muted)}
.goal-bar{height:8px;border-radius:999px;background:var(--bg);overflow:hidden;margin:12px 0 8px}
.goal-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#5bb318,#6EDC2B)}
.goal-foot{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;font-weight:700;color:var(--muted)}
.goal-add{background:rgba(46,58,135,.08);color:var(--navy);font-weight:700;font-size:13px;padding:7px 14px;border:none;border-radius:999px;cursor:pointer}
.goal-add:hover{background:rgba(46,58,135,.16)}

/* Dettes & créances */
.debt-item{background:#fff;border:1px solid var(--line);border-inline-start:4px solid var(--navy);border-radius:14px;padding:14px;margin-bottom:12px}
.debt-item.late{border-inline-start-color:#f43f5e}
.debt-top{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}
.debt-info{min-width:0}
.debt-info b{display:block;font-size:15px;color:var(--navy-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.debt-info span{font-size:12.5px;color:var(--muted)}
.debt-amt{text-align:end;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.debt-amt b{font-size:16px;color:var(--navy-ink)}
.debt-badge{font-size:10.5px;font-weight:800;padding:2px 8px;border-radius:999px}
.debt-badge.paid{background:rgba(110,220,43,.18);color:#2f7a14}
.debt-badge.late{background:rgba(244,63,94,.14);color:#c5283d}
.debt-badge.open{background:rgba(245,158,11,.16);color:#9a5b06}
.debt-actions{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.debt-actions button{flex:1;min-width:120px;background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:9px 12px;font-size:13px;font-weight:600;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}
.debt-actions button:hover{border-color:var(--navy)}

/* Curseur main (pointer) sur tous les boutons d'action cliquables */
.float-add,.float-add *,.global-add,.global-add *,.btn,.btn *,.q-btn,.q-btn *,.cash-act,.cash-act *,.calc-btn,.calc-btn *,.exb-btn,.exb-btn *,.nb-type,.nb-type *,.bk-opt,.bk-opt *,.mini,.mini *,.set-row,.goal-add,.goal-add *,.tva-opt,.ag,.ag *,.sb-link,.sb-link *,.sb-book,.sb-logout,.sb-logout *,.cur-toggle button,.cur-toggle button *,.debt-actions button,.debt-actions button *,.tn-item,.tn-item *,button,button *,[onclick],[onclick] *{cursor:pointer!important}
.float-add,.global-add,.btn,.q-btn,.cash-act,.calc-btn,.exb-btn,.ag,button{user-select:none;-webkit-user-select:none}

/* Budget */
.budget-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:12px}
.budget-item.over{border-color:rgba(244,63,94,.4)}
.budget-h{display:flex;align-items:center;gap:12px;cursor:pointer}
.budget-pct{font-family:var(--display);font-weight:800;font-size:15px;color:var(--navy);flex-shrink:0}
.budget-pct.over{color:#c5283d}
.goal-fill.over{background:linear-gradient(90deg,#c5283d,#f43f5e)}
.budget-alert{margin-top:10px;font-size:12.5px;font-weight:700;color:#c5283d;background:rgba(244,63,94,.10);border-radius:10px;padding:8px 10px}

/* ============================================================
   v1.19 — Simulateurs (crédit / investissement / tontine)
   ============================================================ */
.sim-intro{color:var(--muted);font-size:14px;max-width:720px;margin:-4px 0 16px}
.sim-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.25fr);gap:18px;align-items:start}
@media(max-width:880px){ .sim-grid{grid-template-columns:1fr} }
.sim-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow-sm)}
.sim-slider{margin-bottom:18px}
.sim-lbl{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px;color:var(--navy-ink);font-weight:600;margin-bottom:8px}
.sim-lbl b{font-family:var(--display);font-size:16px;color:var(--navy)}
.sim-sub{display:flex;justify-content:space-between;font-size:11.5px;color:var(--muted);margin-top:6px}
.sim-sub b{color:var(--navy)}
.sim-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sim-card input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:#e7e9f2;outline:none}
.sim-card input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--navy);cursor:pointer;border:3px solid #fff;box-shadow:0 2px 6px rgba(46,58,135,.4)}
.sim-card input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--navy);cursor:pointer;border:3px solid #fff}
.sim-cur{display:flex;align-items:center;justify-content:space-between;margin-top:6px;padding-top:14px;border-top:1px solid var(--line)}
.sim-cur-l{font-size:13px;font-weight:700;color:var(--navy-ink)}
.cur-toggle{display:inline-flex;background:var(--bg);border-radius:10px;padding:3px}
.cur-toggle button{border:none;background:transparent;padding:7px 16px;border-radius:8px;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer}
.cur-toggle button.on{background:var(--lime);color:var(--navy-ink)}
.sim-results{display:flex;flex-direction:column;gap:14px}
.sim-hero{background:linear-gradient(135deg,#eef0fb,#f5f7ff);border:1px solid #e2e6f7;border-radius:16px;padding:18px}
.sh-l{font-size:11.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--navy)}
.sh-v{font-family:var(--display);font-size:30px;font-weight:800;color:var(--navy);line-height:1.1;margin:4px 0}
.sh-v small{font-size:14px;color:var(--muted);font-weight:600}
.sh-break{display:flex;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);margin-top:6px}
.sh-break b{color:var(--navy-ink)}
.sim-detail{background:#fff;border:1px solid var(--line);border-radius:16px;padding:8px 16px}
.sim-detail .cr-row{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.sim-detail .cr-row:last-child{border-bottom:none}
.sim-detail .cr-row.hl{font-weight:800}
.sim-detail .cr-row b.pos{color:#2f7a14}
.sim-chart{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px}
.sim-chart-h{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.sim-chart-h b{font-family:var(--display);color:var(--navy-ink);font-size:15px}
.chart-leg,.donut-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--muted)}
.chart-leg span,.donut-legend>span{display:flex;align-items:center;gap:5px}
.chart-leg i,.donut-legend i{width:10px;height:10px;border-radius:3px;display:inline-block}
.donut-legend{justify-content:center;margin-top:10px}
.sim-chart>div:first-child:has(svg){display:flex;justify-content:center}
.sim-cards3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media(max-width:520px){ .sim-cards3{grid-template-columns:1fr} }
.sc3{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.sc3 span{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:4px}
.sc3 b{font-family:var(--display);font-size:18px;color:var(--navy-ink)}
.sc3.green{background:rgba(110,220,43,.08);border-color:rgba(110,220,43,.3)}
.sc3.green b{color:#2f7a14}
.sc3.navy{background:rgba(46,58,135,.06);border-color:rgba(46,58,135,.25)}
.sc3.navy b{color:var(--navy)}
.sim-note{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:12.5px;color:var(--muted);margin-top:16px;line-height:1.5}
.sim-note.small{margin-top:0;margin-bottom:18px;display:flex;flex-direction:column;gap:3px;background:var(--bg)}
.sim-note.small b{color:var(--navy-ink);font-size:13px;margin-bottom:2px}
/* barres ordre de passage */
.tbars{display:flex;align-items:flex-end;gap:5px;height:130px;overflow-x:auto;padding-top:6px}
.tbar{flex:0 0 22px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:4px}
.tb-fill{width:100%;background:linear-gradient(180deg,#2E3A87,#5b67c4);border-radius:5px 5px 0 0;min-height:8px}
.tb-x{font-size:10px;color:var(--muted)}
/* gestion tontines */
.sim-mgmt{margin-top:22px}
.sim-mgmt .app-sec-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.exb-btn.sm{padding:8px 14px;font-size:13px}
.tn-item{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:10px}
.tn-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px}
.tn-top b{font-size:15px;color:var(--navy-ink)}
.tn-top span{font-size:12px;color:var(--muted);display:block}
.tn-edit{background:var(--bg);border:1px solid var(--line);border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:700;color:var(--navy);cursor:pointer;flex-shrink:0}
.tn-edit:hover{border-color:var(--navy)}
.tn-month{font-size:12.5px;color:var(--muted);margin-bottom:8px}
.tn-month b{color:var(--navy-ink)}
.tn-members{display:flex;flex-wrap:wrap;gap:6px}
.tn-mem{font-size:12px;border-radius:999px;padding:6px 11px;border:1.5px solid var(--line);background:#fff;color:var(--navy-ink);cursor:pointer;font-weight:600;transition:.12s}
.tn-mem.unpaid{background:rgba(244,63,94,.06);border-color:rgba(244,63,94,.25);color:#c5283d}
.tn-mem.paid{background:rgba(110,220,43,.16);border-color:rgba(110,220,43,.45);color:#2f7a14}
.tn-mem:hover{filter:brightness(.98)}
.tn-actions{display:flex;gap:6px;flex-shrink:0}
.tn-benef{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.tn-benef label{font-size:11.5px;font-weight:700;color:var(--muted)}
.tn-benef select{width:100%;padding:9px 12px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-family:inherit;font-size:14px;color:var(--navy-ink);cursor:pointer}
.tn-report{margin-top:10px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.tn-rh,.tn-rr{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:6px;padding:9px 12px;font-size:12px;align-items:center}
.tn-rh{background:var(--navy);color:#fff;font-weight:700;font-size:11px}
.tn-rh span:not(:first-child),.tn-rr span:not(:first-child){text-align:end}
.tn-rr{border-top:1px solid var(--line);color:var(--navy-ink)}
.tn-rr:nth-child(even){background:rgba(46,58,135,.03)}
.tn-rname{font-weight:600}
.tn-rr .pos{color:#2f7a14;font-weight:700}
.tn-rr .neg{color:#c5283d;font-weight:700}
.tn-empty2{padding:14px;text-align:center;color:var(--muted);font-size:12.5px}
.bk-opt{display:flex;align-items:center;gap:12px}
.bk-opt .bk-txt{flex:1;min-width:0}
.bk-rename{flex-shrink:0;width:34px;height:34px;border-radius:10px;background:rgba(46,58,135,.07);border:1px solid var(--line);font-size:15px;display:flex;align-items:center;justify-content:center}
.bk-rename:hover{background:rgba(46,58,135,.14)}

/* Sélecteur de type de compte (inscription) */
.bt-choices{display:flex;flex-direction:column;gap:10px}
.bt-choice{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;padding:12px 14px;border:2px solid var(--line);border-radius:14px;background:#fff;cursor:pointer;transition:.12s;width:100%}
.bt-choice .bt-ico{font-size:20px}
.bt-choice b{font-size:15px;color:var(--navy-ink)}
.bt-choice small{font-size:12px;color:var(--muted)}
.bt-choice.on{border-color:var(--navy);background:rgba(46,58,135,.05)}
.bt-choice:hover{border-color:var(--navy)}

/* Livre non renommable : badge d'affichage seulement (pas de clic) */
.sb-book-static{cursor:default!important}
.sb-book-static:hover{background:transparent!important;filter:none!important}

/* Livre non renommable : affichage statique (pas de curseur main, pas de hover) */
.sb-book-static{cursor:default}
.sb-book-static:hover{background:transparent}
