.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f4f5f7;padding:24px}.login-card{width:100%;max-width:360px;background:#fff;border-radius:12px;padding:32px;box-shadow:0 4px 16px #00000014}.login-card h1{margin:0 0 8px;font-size:20px}.login-card .subtitle{margin:0 0 24px;font-size:13px;color:#6c7280}.login-card form{display:flex;flex-direction:column;gap:8px}.login-card label{font-size:13px;color:#555}.login-card input{padding:10px 12px;border:1px solid #d6d8db;border-radius:8px;font-size:15px;outline:none}.login-card input:focus{border-color:#6f42c1}.login-card button{margin-top:12px;padding:10px 12px;background:#6f42c1;color:#fff;border:none;border-radius:8px;font-size:15px;cursor:pointer}.login-card button:disabled{background:#c6b3e0;cursor:not-allowed}.login-card .hint{margin:0 0 8px;font-size:13px;color:#555}.login-card .link{background:none;color:#6f42c1;border:none;padding:0;font:inherit;cursor:pointer;text-decoration:underline;margin:0}.login-card .error{margin-top:16px;padding:10px 12px;background:#fdecea;color:#b3261e;border-radius:8px;font-size:13px}.app-shell{display:flex;min-height:100vh;background:#f4f5f7;color:#1f2330}.app-sidebar{width:220px;background:#1f2330;color:#d8dbe6;padding:20px 12px;display:flex;flex-direction:column;gap:16px}.app-sidebar-brand{font-size:16px;font-weight:600;color:#fff;padding:0 8px 12px;border-bottom:1px solid #2c3142}.app-sidebar-brand .subtitle{display:block;font-size:11px;font-weight:400;color:#9aa1b3;margin-top:2px}.app-nav{display:flex;flex-direction:column;gap:2px}.app-nav a{padding:8px 12px;border-radius:6px;color:inherit;text-decoration:none;font-size:14px}.app-nav a:hover{background:#2c3142;color:#fff}.app-nav a.active{background:#6f42c1;color:#fff}.app-main{flex:1;display:flex;flex-direction:column;min-width:0}.app-header{height:56px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.app-header-title{font-size:14px;color:#6c7280}.app-logout{background:none;border:1px solid #d6d8db;border-radius:6px;padding:6px 12px;font-size:13px;cursor:pointer}.app-logout:hover{background:#f4f5f7}.app-content{flex:1;padding:24px}.dashboard{display:flex;flex-direction:column;gap:24px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.dashboard-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:8px}.dashboard-card .label{font-size:12px;color:#6c7280;text-transform:uppercase;letter-spacing:.04em}.dashboard-card .value{font-size:28px;font-weight:600;color:#1f2330}.dashboard-card.breakdown .breakdown-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:4px 0}.dashboard-card.breakdown .breakdown-row .k{color:#6c7280}.dashboard-card.breakdown .breakdown-row .v{font-weight:500;color:#1f2330}.dashboard-section-title{font-size:14px;font-weight:600;color:#6c7280;text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px}.dashboard-skeleton .dashboard-card{min-height:96px}.dashboard-skeleton .value-skeleton{width:80px;height:28px;background:#eef0f3;border-radius:4px;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.55}}.workspaces-page{display:flex;flex-direction:column;gap:16px}.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.filters input,.filters select{padding:8px 10px;border:1px solid #d6d8db;border-radius:6px;font-size:13px;background:#fff}.filters input{width:280px}.filters .reset{background:none;border:1px solid #d6d8db;border-radius:6px;padding:8px 12px;font-size:13px;cursor:pointer}.table-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}table.ws-table{width:100%;border-collapse:collapse;font-size:13px}table.ws-table th,table.ws-table td{text-align:left;padding:12px 16px;border-bottom:1px solid #eef0f3}table.ws-table th{background:#f8fafc;font-weight:600;color:#6c7280;text-transform:uppercase;font-size:11px;letter-spacing:.04em}table.ws-table tr:last-child td{border-bottom:none}table.ws-table tbody tr{cursor:pointer}table.ws-table tbody tr:hover{background:#f4f5f7}.empty{padding:32px;text-align:center;color:#6c7280}.load-more{padding:8px 16px;border:1px solid #d6d8db;background:#fff;border-radius:6px;font-size:13px;cursor:pointer}.load-more:disabled{opacity:.6;cursor:not-allowed}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge.type-CHURCH{background:#ede9fe;color:#5b21b6}.badge.type-ORGANIZATION{background:#dbeafe;color:#1d4ed8}.badge.sub-FREE{background:#f3f4f6;color:#4b5563}.badge.sub-ACTIVE{background:#d1fae5;color:#065f46}.badge.sub-PAST_DUE{background:#fee2e2;color:#b91c1c}.badge.sub-GRACE{background:#fef3c7;color:#92400e}.ws-detail{display:flex;flex-direction:column;gap:24px}.ws-detail .back{background:none;border:none;color:#6f42c1;cursor:pointer;font-size:13px;padding:0;text-decoration:underline;align-self:flex-start}.ws-detail .title-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.ws-detail .title-row h2{margin:0}.ws-detail .slug{color:#6c7280;font-size:14px}.ws-detail .section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.ws-detail .section h3{margin:0 0 16px;font-size:13px;color:#6c7280;text-transform:uppercase;letter-spacing:.04em}.ws-detail .kv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px 24px}.ws-detail .kv{display:flex;flex-direction:column;gap:4px}.ws-detail .kv .k{font-size:12px;color:#6c7280;text-transform:uppercase;letter-spacing:.04em}.ws-detail .kv .v{font-size:15px;font-weight:500;color:#1f2330}.ws-detail .placeholder{color:#9ca3af;font-style:italic}.error-banner{background:#fdecea;color:#b3261e;padding:12px 16px;border-radius:8px;font-size:13px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.5;color:#1f2330;-webkit-font-smoothing:antialiased}h1,h2,h3{margin:0 0 16px}p{margin:0 0 12px}.muted{color:#6c7280}code{background:#eef0f3;padding:1px 6px;border-radius:4px;font-size:13px}
