*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:#f5f6f8;color:#111}
.safe-area{min-height:100dvh;display:flex;flex-direction:column}
.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px;background:#fff;border-bottom:1px solid #e5e7eb}
.title-wrap h1{margin:0;font-size:20px;font-weight:800}
.title-wrap p{margin:4px 0 0 0}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.tab{appearance:none;border:0;background:#eee;border-radius:999px;padding:8px 12px;cursor:pointer}
.tab.active{background:#111;color:#fff}
.link{appearance:none;border:1px solid #d1d5db;background:#fff;border-radius:999px;padding:8px 12px;cursor:pointer}
.app-main{max-width:1100px;margin:0 auto;padding:16px;flex:1;display:block}
.center{max-width:520px;margin:40px auto}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 4px 20px rgba(0,0,0,.04)}
.row{display:flex;align-items:center}
.row.between{justify-content:space-between}
.row.gap{gap:8px;flex-wrap:wrap}
label{display:block;margin-top:10px;margin-bottom:6px}
input,select,button{font-size:16px}
input,select{appearance:none;border:1px solid #d1d5db;border-radius:12px;background:#fff;padding:10px 12px}
.primary{appearance:none;border:0;border-radius:999px;background:#111;color:#fff;padding:10px 16px;cursor:pointer}
.secondary{appearance:none;border:1px solid #d1d5db;background:#fff;border-radius:999px;padding:8px 12px;cursor:pointer}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.kpi{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;padding:12px;text-align:center}
.kpi .label{font-size:12px;color:#666}
.kpi .value{font-size:20px;font-variant-numeric:tabular-nums lining-nums}
.kpi .value.strong{font-weight:800}
.list{display:grid;gap:8px}
.item{display:flex;justify-content:space-between;align-items:center;border:1px solid #e5e7eb;border-radius:12px;padding:10px 12px;background:#fff}
.item .sub{font-size:12px;color:#666}
.grid{display:grid;gap:12px}
.grid-3{display:grid;gap:12px}
@media(min-width:860px){.grid{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}}
.muted{color:#666}
.chip{border-radius:999px;border:1px solid #d1d5db;background:#fff;padding:8px 10px}
.kanban{display:grid;gap:8px}
.mt{margin-top:12px}
.grid2{display:grid;gap:10px}
@media(min-width:680px){.grid2{grid-template-columns:1fr 1fr}}
.app-footer{margin-top:auto;padding:16px;text-align:center;color:#94a3b8}
