:root{--bg:#0a0a0f;--panel:#222530;--muted:#9ca3af;--text:#f3f4f6;--primary:#7c5cff;--primary-2:#5b3df0;--accent:#24d2a7;--danger:#ff5c7c}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}
.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(180deg,rgba(34,37,48,.95),rgba(34,37,48,.85));backdrop-filter:saturate(140%) blur(6px);border-bottom:1px solid rgba(255,255,255,.12)}
.app-header .logo{height:28px}
.app-header .spacer{flex:1}
.user-chip{font-size:.9rem;color:var(--muted)}

.container{padding:1rem;flex:1;padding-bottom:150px}
.screen{padding:1rem;display:flex;flex-direction:column;gap:1rem}

.card{background:var(--panel);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:1rem;box-shadow:0 2px 8px rgba(0,0,0,.15)}
.usercard{display:flex;align-items:center;gap:.75rem;position:relative}
.health-icon{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;border-radius:50%;background:var(--accent);color:#000;display:grid;place-items:center;font-size:.8rem;font-weight:700;cursor:pointer;transition:transform 0.2s}
.health-icon:hover{transform:scale(1.1)}
.avatar{width:48px;height:48px;border-radius:50%;background:#2a2f42;background-size:cover;background-position:center center;background-repeat:no-repeat}
.avatar.large{width:84px;height:84px}
.avatar.addable{position:relative;}
.avatar.addable::after{content:'+';position:absolute;right:-6px;bottom:-6px;width:22px;height:22px;border-radius:50%;background:#ffa500;color:#000;display:grid;place-items:center;font-weight:700;border:2px solid var(--bg)}
.avatar.addable{cursor:pointer}
.user-infos .name{font-weight:700}
.user-infos .meta{color:var(--muted);font-size:.9rem}

.list{display:flex;flex-direction:column;gap:.5rem}
.list .row{display:flex;justify-content:space-between;align-items:center;background:var(--panel);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:.75rem 1rem}
.badge{font-size:.75rem;padding:.2rem .5rem;border-radius:999px;background:#2a2f42;color:var(--muted)}
.badge.paid{background:rgba(36,210,167,.15);color:var(--accent)}
.badge.unpaid{background:rgba(255,92,124,.12);color:var(--danger)}

.btn{appearance:none;border:none;border-radius:12px;padding:.75rem 1rem;background:#2a2f42;color:var(--text);font-weight:600;cursor:pointer}
.btn.primary{background:linear-gradient(180deg,var(--primary),var(--primary-2));}
.btn.secondary{background:linear-gradient(180deg,#ffa500,#ff8c00);color:#000}
.btn.danger{background:linear-gradient(180deg,var(--danger),#e04a6b);}
.btn:active{transform:translateY(1px)}
.activity-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}
.price-info{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}
.price-original{text-decoration:line-through;color:var(--muted);font-size:.85rem}
.price-current{font-weight:600;color:var(--text)}
.row-actions{display:flex;gap:.25rem}
.btn.small{padding:.4rem .6rem;font-size:.8rem}

.form{display:flex;flex-direction:column;gap:1rem;margin-bottom:5rem}
.form label{display:flex;flex-direction:column;gap:.35rem;color:var(--muted);font-size:.9rem}
.form input{appearance:none;border:1px solid rgba(255,255,255,.08);background:#121522;color:var(--text);padding:.75rem;border-radius:10px}
.form .grid{display:grid;grid-template-columns:1fr;gap:.75rem}
@media(min-width:720px){.form .grid{grid-template-columns:1fr 1fr}}
.row{display:flex;gap:.5rem;align-items:center}

.hidden{display:none !important}
.modal{position:fixed;inset:0;display:grid;place-items:end center;background:rgba(0,0,0,.35);z-index:1000}
.modal.hidden{display:none}
.modal .modal-content{width:100%;max-width:640px;background:var(--panel);border:1px solid rgba(255,255,255,.12);border-radius:16px 16px 0 0;padding:1rem;max-height:75vh;overflow:auto;box-shadow:0 -4px 20px rgba(0,0,0,.3)}

.tabbar{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:1fr 1fr 1fr 1fr;background:rgba(34,37,48,.95);backdrop-filter:saturate(140%) blur(6px);border-top:1px solid rgba(255,255,255,.12);z-index:20}
.tabbar .tab{padding:.8rem 1rem;text-align:center;color:var(--muted);text-decoration:none;font-size:.85rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}
.tabbar .tab:hover{color:var(--text)}
.tabbar .tab::before{font-size:1.2rem;content:'🏠'}
.tabbar .tab[href*="/user"]::before{content:'👤'}
.tabbar .tab[href*="/sante"]::before{content:'🏥'}
.tabbar .tab[href*="/historique"]::before{content:'📊'}

/* Health status indicators */
.status-valid{color:var(--accent);background:rgba(36,210,167,.1);padding:1rem;border-radius:12px;border:1px solid rgba(36,210,167,.2)}
.status-invalid{color:var(--danger);background:rgba(255,92,124,.1);padding:1rem;border-radius:12px;border:1px solid rgba(255,92,124,.2)}
.status-missing{color:var(--muted);background:rgba(139,146,166,.1);padding:1rem;border-radius:12px;border:1px solid rgba(139,146,166,.2)}
.status-missing.clickable{background:rgba(255,165,0,.15);border-color:rgba(255,165,0,.3);color:#ffa500;cursor:pointer;transition:all 0.2s}
.status-missing.clickable:hover{background:rgba(255,165,0,.25);transform:translateY(-1px)}

/* CERFA form styling */
.cerfa-form{background:white;color:#000;padding:1.5rem;border-radius:12px;margin:1rem 0}
.cerfa-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #000}
.logo-republique{height:60px}
.cerfa-title h3{font-size:1.2rem;margin:0;font-weight:700}
.cerfa-title p{margin:.25rem 0;font-size:.9rem}
.cerfa-ref{font-size:.8rem;color:#666;font-style:italic}
.form-section{margin:1.5rem 0}
.form-section h4{font-size:1rem;margin-bottom:1rem;color:#000;font-weight:600}
.question{margin:1rem 0;padding:.75rem;background:#f8f9fa;border-radius:8px}
.question p{margin:0 0 .75rem 0;font-weight:500}
.radio-group{display:flex;gap:1rem}
.radio-group label{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.radio-group input[type="radio"]{margin:0}
.form-footer{margin-top:2rem;padding-top:1rem;padding-bottom:2rem;border-top:1px solid #ddd}
.warning{color:#d63384;font-size:.9rem;margin-bottom:1rem}

