*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1a1d27;--surface2: #22263a;--border: #2e3248;--text-1: #e2e8f0;--text-2: #94a3b8;--accent: #4f8ef7;--radius: 12px;--shadow: 0 4px 24px rgba(0,0,0,.4)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text-1);min-height:100vh}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:radial-gradient(ellipse at 50% 0%,#1e2a4a 0%,var(--bg) 70%)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center}.login-logo{font-size:2.5rem;margin-bottom:12px}.login-title{font-size:1.6rem;font-weight:700;color:var(--text-1);margin-bottom:6px}.login-subtitle{font-size:.9rem;color:var(--text-2);margin-bottom:28px}.login-form{display:flex;flex-direction:column;gap:16px;text-align:left}.login-field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.login-field input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text-1);font-size:1rem;outline:none;transition:border-color .2s}.login-field input:focus{border-color:var(--accent)}.login-error{font-size:.88rem;color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.25);border-radius:8px;padding:8px 12px}.login-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;margin-top:4px}.login-btn:hover:not(:disabled){opacity:.88}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:default}.dash-wrap{min-height:100vh;display:flex;flex-direction:column}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:60px;background:var(--surface);border-bottom:1px solid var(--border)}.dash-logo{font-size:1.1rem;font-weight:700;color:var(--text-1);display:flex;align-items:center;gap:8px}.dash-logout{background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);padding:6px 14px;font-size:.88rem;cursor:pointer;transition:background .15s,color .15s}.dash-logout:hover{background:var(--surface2);color:var(--text-1)}.dash-main{flex:1;padding:40px 28px;max-width:960px;margin:0 auto;width:100%}.dash-title{font-size:1.1rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.app-card{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-decoration:none;color:var(--text-1);transition:border-color .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden}.app-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);border-radius:3px 0 0 3px}.app-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.app-card-icon{font-size:2rem;flex-shrink:0}.app-card-body{flex:1;min-width:0}.app-card-name{font-size:1.05rem;font-weight:600;margin-bottom:4px}.app-card-desc{font-size:.85rem;color:var(--text-2);line-height:1.4}.app-card-arrow{font-size:1.2rem;color:var(--text-2);flex-shrink:0;transition:transform .2s,color .2s}.app-card:hover .app-card-arrow{transform:translate(4px);color:var(--accent)}.dash-header-actions{display:flex;align-items:center;gap:8px}.dash-btn{background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);padding:6px 14px;font-size:.88rem;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.dash-btn:hover{background:var(--surface2);color:var(--text-1)}.dash-btn-icon{display:none}@media (max-width: 560px){.dash-header{padding:0 12px;gap:6px}.dash-btn:first-of-type .dash-btn-label{display:none}.dash-btn .dash-btn-label{display:inline;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-btn{padding:6px 10px}.dash-logout .dash-btn-label{display:none}.dash-btn-icon{display:inline}.dash-logout{padding:6px 10px;min-width:34px;justify-content:center}.dash-logo span{font-size:.95rem}}.dash-back{background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-2);padding:6px 14px;font-size:.88rem;cursor:pointer;transition:background .15s,color .15s}.dash-back:hover{background:var(--surface2);color:var(--text-1)}.page-wrap{min-height:100vh;display:flex;flex-direction:column}.page-main{flex:1;padding:32px 16px;max-width:600px;margin:0 auto;width:100%}.page-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}.page-user-info{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}.page-user-avatar{font-size:2.4rem;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:50%;flex-shrink:0}.page-user-name{font-size:1.15rem;font-weight:700;color:var(--text-1)}.page-user-role{font-size:.85rem;color:var(--text-2);margin-top:3px}.page-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.page-tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-2);padding:8px 16px;font-size:.9rem;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.page-tab:hover{color:var(--text-1)}.page-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.page-form{display:flex;flex-direction:column;gap:16px}.page-field{display:flex;flex-direction:column;gap:6px}.page-field label{font-size:.8rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.page-field input,.page-field select{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;color:var(--text-1);font-size:1rem;outline:none;transition:border-color .2s}.page-field input:focus,.page-field select:focus{border-color:var(--accent)}.page-field select option{background:var(--surface2)}.page-msg{font-size:.88rem;border-radius:8px;padding:8px 12px}.page-msg.error{color:#f87171;background:#f871711a;border:1px solid rgba(248,113,113,.25)}.page-msg.success{color:#4ade80;background:#4ade801a;border:1px solid rgba(74,222,128,.25)}.page-msg.info{color:var(--text-2);background:var(--surface2);border:1px solid var(--border)}.page-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:11px 20px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s;align-self:flex-start}.page-btn:hover:not(:disabled){opacity:.88}.page-btn:active:not(:disabled){transform:scale(.98)}.page-btn:disabled{opacity:.5;cursor:default}.page-btn.outline{background:transparent;border:1px solid var(--border);color:var(--text-2)}.page-btn.outline:hover{background:var(--surface2);color:var(--text-1)}.page-btn-sm{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text-1);padding:6px 14px;font-size:.85rem;cursor:pointer;transition:background .15s;white-space:nowrap}.page-btn-sm:hover{background:var(--border)}.users-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.users-title{font-size:1.05rem;font-weight:700;color:var(--text-1)}.users-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.user-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 16px;transition:border-color .15s}.user-row.self{border-color:#4f8ef759}.user-row-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}.user-row-name{font-weight:600;font-size:.95rem;color:var(--text-1)}.user-row-you{font-size:.8rem;color:var(--text-2);font-weight:400}.user-row-role{font-size:.78rem;padding:2px 8px;border-radius:20px;font-weight:600}.user-row-role.admin{background:#facc1526;color:#fbbf24}.user-row-role.user{background:#94a3b81f;color:var(--text-2)}.user-row-role.editor{background:#34d3991f;color:#34d399}.user-row-role.viewer{background:#94a3b814;color:#64748b}.user-row-date{font-size:.78rem;color:var(--text-2)}.user-row-actions{display:flex;gap:6px;flex-shrink:0}.user-action-btn{width:32px;height:32px;background:var(--surface);border:1px solid var(--border);border-radius:7px;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.user-action-btn:hover{background:var(--border)}.user-action-btn.danger:hover{background:#f8717133;border-color:#f8717166}.add-form{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:8px}.add-form-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:12px}@media (max-width: 560px){.add-form-fields{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;width:100%;max-width:380px;box-shadow:var(--shadow)}.modal-title{font-size:1.05rem;font-weight:700;color:var(--text-1);margin-bottom:20px}.modal-actions{display:flex;gap:10px;margin-top:16px;justify-content:flex-end}
