:root{
  --bg:#f6f7fc; --card:#fff; --ink:#1a1c2e; --muted:#7a7f9a;
  --brand:#3b5bff; --brand2:#5a3bff; --brand-soft:#eef1ff;
  --green:#16b364; --green-soft:#e6f8ee; --amber:#f5a524; --amber-soft:#fff4e0;
  --line:#eceefa; --radius:20px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
body{font-family:var(--font);background:#e9ebf5;color:var(--ink)}
.app{position:relative;max-width:480px;min-height:100vh;margin:0 auto;background:var(--bg);
  box-shadow:0 0 40px rgba(20,26,80,.12);overflow:hidden;display:flex;flex-direction:column}
.view{flex:1;overflow-y:auto;padding:14px 18px 110px;-webkit-overflow-scrolling:touch}
.view::-webkit-scrollbar{width:0}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 2px 14px}
.topbar small{color:var(--muted);font-size:12px;font-weight:600}
.topbar h2{font-size:22px;font-weight:800;letter-spacing:-.4px}
.avatar{width:40px;height:40px;border-radius:14px;background:linear-gradient(135deg,var(--brand),var(--brand2));
  color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:13px}

.hero{background:linear-gradient(135deg,var(--brand),var(--brand2));border-radius:var(--radius);padding:20px;color:#fff;
  box-shadow:0 14px 28px rgba(59,91,255,.34);position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;background:rgba(255,255,255,.12);border-radius:50%}
.hero small{opacity:.85;font-size:12.5px;font-weight:600}
.hero .amt{font-size:33px;font-weight:800;margin-top:4px;letter-spacing:-1px}
.hero .sub{display:flex;gap:16px;margin-top:14px;font-size:12.5px}
.hero .sub b{display:block;font-size:15px;font-weight:800;margin-top:1px}
.hero .sub span{opacity:.82}
.breakdown{display:flex;gap:8px;margin-top:14px}
.bd{flex:1;background:rgba(255,255,255,.13);border-radius:12px;padding:9px 6px;text-align:center}
.bd .gi{font-size:16px}.bd b{display:block;font-size:11px;font-weight:800;margin-top:3px}

.section-t{display:flex;align-items:center;justify-content:space-between;margin:22px 2px 12px}
.section-t h3{font-size:15px;font-weight:800}
.lnk{color:var(--brand);font-size:12.5px;font-weight:700;cursor:pointer}

.exp{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:11px 12px;display:flex;gap:11px;
  align-items:center;margin-bottom:10px;box-shadow:0 5px 14px rgba(20,26,80,.05);cursor:pointer;position:relative}
.exp:active{transform:scale(.99)}
.exp .ico{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto}
.exp .mid{flex:1;min-width:0}
.exp .mid b{font-size:13.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.exp .mid p{color:var(--muted);font-size:11.5px;margin-top:2px}
.exp .tags{margin-top:6px;display:flex;gap:5px;flex-wrap:wrap}
.tag{font-size:10.5px;font-weight:700;padding:3px 7px;border-radius:7px}
.tag.tn{background:#f1f2f8;color:var(--muted)}.tag.ta{background:var(--amber-soft);color:#b06d00}
.exp .amt{text-align:right;flex:0 0 auto}
.exp .amt b{font-size:14px;font-weight:800}.exp .amt small{display:block;color:var(--muted);font-size:10.5px}
.exp .del{position:absolute;top:8px;right:8px;border:none;background:#f1f2f8;color:var(--muted);width:22px;height:22px;
  border-radius:7px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.exp .del:hover{background:#ffe1ea;color:#f4467d}
.empty{text-align:center;color:var(--muted);padding:36px 0;font-size:13px}

.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin-bottom:12px}
.chips::-webkit-scrollbar{height:0}
.chip{flex:0 0 auto;border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:999px;
  padding:7px 13px;font-size:12px;font-weight:700;cursor:pointer}
.chip.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.totalbar{background:#fff;border:1px dashed var(--line);border-radius:14px;padding:14px;text-align:center;font-size:13px;color:var(--muted)}
.totalbar b{color:var(--ink)}

.card{background:var(--card);border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:0 5px 14px rgba(20,26,80,.05);margin-bottom:4px}
.card.pad2{padding:16px}
.card h4{font-size:15px;font-weight:800;display:flex;justify-content:space-between;align-items:center}
.accent{color:var(--brand);font-size:17px}
.row{display:flex;gap:12px;align-items:center;padding:13px 14px;border-bottom:1px solid var(--line)}
.row:last-child{border-bottom:none}
.row .ic{width:34px;height:34px;border-radius:10px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex:0 0 auto}
.row .ct{flex:1}.row .ct b{font-size:13.5px;display:block}.row .ct small{color:var(--muted);font-size:11.5px}
.row select{border:1px solid var(--line);border-radius:10px;padding:7px 9px;font-family:inherit;font-size:13px;font-weight:700;color:var(--ink);background:#fff}
.row .val{font-size:12.5px;font-weight:700;color:var(--muted)}.row .val.ok{color:var(--green)}
.on-dot{width:38px;height:22px;border-radius:99px;background:var(--green);position:relative;flex:0 0 auto}
.on-dot::after{content:"";position:absolute;top:3px;right:3px;width:16px;height:16px;border-radius:50%;background:#fff}

.dl{display:flex;align-items:center;gap:10px;width:100%;border-radius:13px;padding:13px 14px;margin-top:8px;
  cursor:pointer;border:1px solid;font-size:13px;font-weight:700;font-family:inherit}
.dl .b{width:38px;height:30px;border-radius:8px;color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800}
.dl.xls{background:var(--green-soft);border-color:#c8efd8;color:#0c7a45}.dl.xls .b{background:var(--green)}
.dl.csv{background:var(--brand-soft);border-color:#d2dbff;color:var(--brand)}.dl.csv .b{background:var(--brand)}
.muted{color:var(--muted);font-size:12.5px}.center{text-align:center;margin-top:14px}

/* nav + fab */
.nav{position:sticky;bottom:0;height:72px;background:rgba(255,255,255,.94);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-around;padding:0 8px 8px;z-index:20}
.nav button{background:none;border:none;display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--muted);font-size:10px;font-weight:700;cursor:pointer;flex:1}
.nav button .gi{font-size:20px}.nav button.on{color:var(--brand)}
.fab{position:absolute;bottom:84px;right:18px;width:58px;height:58px;border-radius:19px;
  background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border:none;font-size:30px;font-weight:300;
  box-shadow:0 12px 24px rgba(59,91,255,.45);cursor:pointer;z-index:25;display:flex;align-items:center;justify-content:center}
.fab:active{transform:scale(.94)}

/* overlay: sheet + modal */
.overlay{position:fixed;inset:0;z-index:40;display:none;max-width:480px;margin:0 auto}
.overlay.show{display:block}
.sheet-bg{position:absolute;inset:0;background:rgba(10,12,28,.5)}
.sheet{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:24px 24px 0 0;padding:16px 18px 26px;
  transform:translateY(110%);transition:transform .28s cubic-bezier(.2,.8,.2,1)}
.sheet.up{transform:translateY(0)}
.sheet .grab{width:42px;height:5px;background:#dfe1ee;border-radius:9px;margin:0 auto 14px}
.sheet h3{font-size:16px;font-weight:800;margin-bottom:14px}
.catgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.catbtn{background:#f6f7fc;border:1px solid var(--line);border-radius:16px;padding:14px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:7px}
.catbtn .ico{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.catbtn b{font-size:11.5px;font-weight:700;color:var(--ink)}

.modal{position:absolute;inset:0;background:var(--bg);overflow-y:auto;animation:slideup .25s ease}
@keyframes slideup{from{transform:translateY(20px);opacity:.6}to{transform:translateY(0);opacity:1}}
.mhead{display:flex;align-items:center;justify-content:space-between;color:#fff;padding:16px 16px;
  font-weight:700;font-size:14px;position:sticky;top:0;z-index:2}
.iconbtn{background:rgba(255,255,255,.2);border:none;color:#fff;width:34px;height:34px;border-radius:10px;font-size:15px;cursor:pointer}
.mbody{padding:16px 18px 40px}
.mbody label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin:12px 0 0}
.mbody input,.mbody select{width:100%;border:1px solid var(--line);background:#fff;border-radius:12px;
  padding:11px 12px;font-size:14px;font-family:inherit;color:var(--ink);margin-top:5px;font-weight:600}
.mbody input:focus,.mbody select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.hint{display:block;font-weight:500;color:#a7abc4;margin-top:2px}
.rowflex{display:flex;gap:10px}.rowflex>label{flex:1}
label.sw{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:11px 12px;margin-top:10px;font-size:13px;color:var(--ink);font-weight:700}
label.sw input{width:auto;margin:0}

.calc{background:linear-gradient(135deg,#101637,#1b2350);color:#fff;border-radius:14px;padding:14px 16px;margin-top:16px}
.cl{display:flex;justify-content:space-between;font-size:12.5px;padding:4px 0;color:#c7cdf0}
.cl.tot{border-top:1px solid rgba(255,255,255,.15);margin-top:8px;padding-top:11px;color:#fff;font-weight:800;font-size:15px}
.cl.tot span:last-child{font-size:19px}

.attbox{background:#fff;border:1px solid var(--line);border-radius:13px;padding:13px;margin-top:12px}
.atth{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.atth b{font-size:13px}
.chiprow{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.pchip{display:flex;gap:6px;align-items:center;background:var(--brand-soft);color:var(--brand);border-radius:999px;padding:5px 10px;font-size:11.5px;font-weight:700}
.pchip i{cursor:pointer;font-style:normal;opacity:.7}
.addbtn{border:none;background:var(--brand);color:#fff;border-radius:10px;width:42px;font-size:20px;cursor:pointer;margin-top:5px}
.primary{margin-top:18px;width:100%;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;border:none;
  padding:15px;border-radius:14px;font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 12px 24px rgba(59,91,255,.4)}
.orsbtn{margin-top:10px;width:100%;background:var(--brand-soft);color:var(--brand);border:1px solid #d2dbff;
  padding:11px;border-radius:12px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer}
.orsbtn:disabled{opacity:.6;cursor:default}
.keyrow{padding:0 14px 14px}
.keyrow input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:inherit;font-size:13px;color:var(--ink)}
.keyrow input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}

.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:#101637;color:#fff;
  padding:11px 18px;border-radius:12px;font-size:12.5px;font-weight:700;opacity:0;transition:.3s;z-index:60;
  pointer-events:none;box-shadow:0 10px 24px rgba(0,0,0,.3);white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media(min-width:481px){ body{padding:0} }

/* Agenda import */
.agbanner{display:flex;gap:11px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:13px 14px;margin-top:14px;box-shadow:0 5px 14px rgba(20,26,80,.05);cursor:pointer}
.agbanner .ic{width:42px;height:42px;border-radius:13px;background:var(--green-soft);display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto}
.agbanner .ct{flex:1}.agbanner .ct b{font-size:13.5px;display:block}.agbanner .ct small{color:var(--muted);font-size:11.5px}
.agbanner .chev{color:var(--brand);font-weight:800}
.chev{color:var(--muted)}
.filebtn{display:block;width:100%;text-align:center;background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:12px;margin-top:10px;font-size:13px;font-weight:700;color:var(--ink);cursor:pointer}
.agitem{display:flex;gap:10px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 12px;margin-top:10px;cursor:pointer}
.agitem input{width:auto;margin:0;flex:0 0 auto}
.agitem .ct{flex:1;min-width:0}.agitem .ct b{font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.agitem .ct small{color:var(--muted);font-size:11.5px}

/* Justificatif OCR */
.receiptbox{margin-top:10px}
.recprev{margin-top:8px}
.recprev img{max-width:100%;max-height:200px;border-radius:12px;border:1px solid var(--line)}

/* Compte & sync */
.authbtns{display:flex;gap:8px}
.authbtns .orsbtn{flex:1}
.orsbtn.danger{background:#ffe1ea;color:#f4467d;border-color:#ffc9d8}

/* Invite d'installation PWA */
.installbar{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#3b5bff,#5a3bff);color:#fff;padding:10px 14px;font-size:13px;font-weight:600}
.installbar .installbtn{margin-left:auto;background:#fff;color:#3b5bff;border:none;border-radius:10px;padding:8px 12px;font-size:12.5px;font-weight:800;cursor:pointer}
.installbar .installx{background:transparent;border:none;color:#fff;font-size:15px;cursor:pointer;opacity:.85}
.ios-modal{position:fixed;inset:0;background:rgba(10,12,28,.55);display:flex;align-items:center;justify-content:center;z-index:999;padding:18px}
.ios-card{background:#fff;border-radius:18px;padding:20px;max-width:340px}
.ios-card h3{font-size:16px;font-weight:800;margin-bottom:10px}
.ios-card ol{margin:0 0 14px 1.1rem;font-size:13.5px;line-height:1.7;color:#1a1c2e}
.ios-card .ios-close{width:100%;background:linear-gradient(135deg,#3b5bff,#5a3bff);color:#fff;border:none;border-radius:12px;padding:12px;font-weight:800;cursor:pointer}

/* Porte de connexion */
.authgate{position:fixed;inset:0;z-index:1000;background:linear-gradient(160deg,#0f1226,#1b2150 60%,#23295c);
  display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto}
.auth-card{background:#fff;border-radius:22px;padding:24px;width:100%;max-width:380px;box-shadow:0 30px 60px rgba(0,0,0,.35)}
.auth-logo{font-size:24px;font-weight:800;color:#3b5bff;text-align:center}
.auth-tag{text-align:center;color:#7a7f9a;font-size:13px;margin:4px 0 16px}
.auth-tabs{display:flex;background:#eef0f7;border-radius:12px;padding:4px;margin-bottom:14px}
.auth-tabs button{flex:1;border:none;background:none;padding:9px;border-radius:9px;font-size:13px;font-weight:700;color:#7a7f9a;cursor:pointer}
.auth-tabs button.on{background:#fff;color:#3b5bff;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.auth-card input{width:100%;border:1px solid #eceefa;border-radius:12px;padding:12px;font-size:14px;margin-bottom:10px;font-family:inherit}
.auth-card input:focus{outline:none;border-color:#3b5bff;box-shadow:0 0 0 3px #eef1ff}
.auth-go{width:100%;background:linear-gradient(135deg,#3b5bff,#5a3bff);color:#fff;border:none;border-radius:13px;padding:14px;font-size:15px;font-weight:800;cursor:pointer;box-shadow:0 12px 24px rgba(59,91,255,.4)}
.auth-go:disabled{opacity:.6}
.auth-err{color:#f4467d;font-size:12.5px;font-weight:600;margin-bottom:8px;min-height:1em}
.auth-note{font-size:11.5px;color:#7a7f9a;text-align:center;margin-top:12px}
.auth-link{text-align:center;margin-top:10px}
.auth-link a{color:#3b5bff;font-size:12.5px;font-weight:700;text-decoration:none}

/* Barre du site dans l'app */
.sitebar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 14px;background:#fff;border-bottom:1px solid var(--line)}
.sitebar .sb-logo{font-weight:800;color:var(--brand);text-decoration:none;font-size:15px}
.sitebar .sb-nav{display:flex;gap:14px}
.sitebar .sb-nav a{color:var(--muted);text-decoration:none;font-size:12.5px;font-weight:700}
.sitebar .sb-nav a:hover{color:var(--brand)}
