:root{--bg:#f5f7fc;--panel:#fff;--text:#13233c;--muted:#60708a;--line:#e4e9f3;--pri:#3a66ff;--ok:#1f9d55;--warn:#ba7f00}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%}body{margin:0;font-family:Inter,system-ui,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%}.app-shell{min-height:100vh;display:grid;place-items:center;background:linear-gradient(180deg,#f8faff,#eef3ff);padding:16px}.login-card{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:0 14px 30px #13233c1f}.login-card .stack{display:grid;gap:10px}.login-card label{display:grid;gap:6px;font-size:12px;color:var(--muted)}.login-card input{border:1px solid var(--line);border-radius:10px;padding:10px 11px;font-size:16px;min-height:40px}.login-card .row{display:flex;gap:8px;align-items:center}.login-card .btn{height:40px;border-radius:10px;padding:10px 12px;border:1px solid var(--pri);background:var(--pri);color:#fff;font-weight:700;cursor:pointer}.login-card .btn.secondary{border-color:var(--line);background:#fff;color:var(--text)}.app-brand{display:flex;align-items:center;gap:12px;margin-bottom:12px}.app-brand img{width:46px;height:46px;border-radius:10px;border:1px solid var(--line);background:#fff;padding:4px}.app-brand-title{font-size:18px;line-height:1.2;margin:0;font-weight:700}.app-brand-subtitle{margin:2px 0 0;font-size:12px;color:var(--muted)}.error-text{font-size:13px;color:#b42318}.auth-input,input[name=username],input[name=password],input[autocomplete=username],input[autocomplete=current-password],.login-card input{font-size:16px!important}.auth-input:focus,input[name=username]:focus,input[name=password]:focus,input[autocomplete=username]:focus,input[autocomplete=current-password]:focus,.login-card input:focus{font-size:16px!important}.auth-input:-webkit-autofill,input[name=username]:-webkit-autofill,input[name=password]:-webkit-autofill,input[autocomplete=username]:-webkit-autofill,input[autocomplete=current-password]:-webkit-autofill,.login-card input:-webkit-autofill{font-size:16px!important}.layout{display:grid;grid-template-columns:220px 1fr;min-height:100vh}aside{background:#202b45;color:#eaf0ff;padding:14px}.brand{display:flex;align-items:center;gap:8px;font-weight:800;margin:8px 8px 14px}.brand-badge{width:24px;height:24px;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:#fff;object-fit:contain;padding:2px}.nav a{display:block;color:inherit;text-decoration:none;padding:10px 12px;border-radius:10px;margin:4px 0}.nav a.active{background:#334468}main{padding:14px 14px 92px;max-width:100vw;overflow-x:hidden}.header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:10px}.title-wrap{display:flex;align-items:center;gap:10px}.title-chip{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;display:grid;place-items:center;overflow:hidden}.title-chip img{width:100%;height:100%;object-fit:contain;padding:3px}.title-text h1{display:block;margin:0;font-size:18px;line-height:1.2}.title-text p{margin:2px 0 0;color:var(--muted);font-size:12px}.top-nav{display:flex;align-items:center;gap:8px;margin-left:auto}.menu-toggle{display:none;border-radius:999px;padding:8px 12px;background:linear-gradient(180deg,#fff,#f7f9ff);box-shadow:0 4px 10px #13233c14}.top-links{display:flex;gap:8px}.top-links .btn{border-radius:999px}.top{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.search{display:flex;flex:1;min-width:220px;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden}.search input{border:0;outline:0;padding:10px 12px;flex:1}.btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:9px 12px;font-weight:600;cursor:pointer;color:var(--text)}.btn.primary{background:var(--pri);border-color:var(--pri);color:#fff}.btn.danger{background:#b42318;border-color:#b42318;color:#fff}.btn.sm{padding:6px 9px;font-size:12px}.btn.ghost-danger{background:#fff;border-color:#f2c7c7;color:#b42318}.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px;box-shadow:0 8px 20px #15223812}.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:12px 0}.k{font-size:12px;color:var(--muted)}.v{font-size:22px;font-weight:800}.last-sync{font-size:15px}table{width:100%;border-collapse:collapse}.table-wrap{width:100%;overflow-x:auto}.users-table{min-width:680px}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left}th{font-size:12px;color:var(--muted);text-transform:uppercase}.tag{padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700}.ok{background:#e8f7ef;color:var(--ok)}.warn{background:#fff4de;color:var(--warn)}.details{background:#fbfcff}.meta{font-size:12px;color:var(--muted)}.user-actions{display:flex;gap:8px;flex-wrap:wrap}.user-actions .btn{min-width:92px;justify-content:center;display:inline-flex;align-items:center}.tab{display:none}.tab.active{display:block}.users-workspace{display:grid;grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:10px;align-items:start}.family-workspace-card .family-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.family-workspace-card .family-meta-grid span{display:block}.family-workspace-card .family-meta-grid strong{display:block;margin-top:2px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px;word-break:break-all}.users-bottom-bar{grid-template-columns:minmax(0,220px)}.row-actions{display:flex;gap:6px;justify-content:flex-end}.item-cell{display:flex;align-items:center;justify-content:space-between;gap:8px}.qr-print-view{display:grid;place-items:center;gap:8px}.bottom-bar{position:fixed;left:220px;right:0;bottom:0;background:linear-gradient(180deg,#fff,#f7f9ff);border-top:1px solid var(--line);padding:8px 12px;display:grid;grid-template-columns:repeat(3,minmax(0,220px));justify-content:center;gap:10px;z-index:30;align-items:center;box-shadow:0 -8px 20px #13233c14}.bottom-bar .btn{width:100%;min-height:40px;padding:8px 12px;font-size:13px;line-height:1.2;border-radius:999px;white-space:nowrap;display:flex;align-items:center;justify-content:center;text-align:center;box-shadow:0 6px 14px #13233c24}.bottom-bar .btn.primary{box-shadow:0 6px 14px #3a66ff40}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182773;display:none;align-items:center;justify-content:center;padding:16px;z-index:40;pointer-events:none}.modal.open{display:flex;pointer-events:auto}.modal-card{width:min(620px,100%);background:#fff;border:1px solid var(--line);border-radius:14px;max-height:90vh;overflow:auto}.mh{padding:12px 14px;border-bottom:1px solid var(--line);font-weight:800}.mb{padding:14px}.mf{padding:12px 14px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}.field{display:grid;gap:6px;margin-bottom:10px}.field label{font-size:12px;color:var(--muted)}.field input,.field select{border:1px solid var(--line);border-radius:10px;padding:9px}.two{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inline-error{position:fixed;right:10px;bottom:64px;z-index:50;background:#fff3f2;border:1px solid #f3c3c1;padding:10px;border-radius:10px;display:flex;align-items:center;gap:8px}.inline-error p{margin:0;font-size:13px;color:#8a1d17}.inline-success{position:fixed;right:10px;bottom:64px;z-index:50;background:#eefaf1;border:1px solid #b7e3c1;padding:10px;border-radius:10px;display:flex;align-items:center;gap:8px}.inline-success p{margin:0;font-size:13px;color:#116329}@media (max-width:900px){.layout{grid-template-columns:1fr}aside{display:none}main{padding:10px 10px 106px}.bottom-bar{left:0}.stats{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:760px){.top{gap:8px}.search{min-width:0;width:100%}.bottom-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:visible;white-space:normal;gap:8px}.users-workspace{grid-template-columns:1fr}.users-table{min-width:620px}.family-workspace-card .family-meta-grid{grid-template-columns:1fr}.bottom-bar .btn{width:100%}.two{grid-template-columns:1fr}th,td{padding:8px;font-size:13px}.card{padding:10px}.menu-toggle{display:inline-block}.top-links{display:none;position:absolute;right:10px;top:60px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px;flex-direction:column;box-shadow:0 10px 24px #13233c1f}.top-links.open{display:flex}.top-links .btn{width:140px;text-align:left}}@media print{body *{visibility:hidden!important}#qrPrintArea,#qrPrintArea *{visibility:visible!important}#qrPrintArea{position:absolute;left:0;top:0;width:100%;padding:24px}}
