*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:#e2e8f0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0c0f14;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif}:root{--bg:#0c0f14;--surface:#151921;--surface-hover:#1c2333;--border:#1e2a3a;--accent:#3b82f6;--text:#e2e8f0;--text-dim:#94a3b8;--text-muted:#64748b;--radius:12px;--radius-lg:16px}.page-center{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-box{background:var(--surface);border-radius:var(--radius);text-align:center;border:1px solid #ef4444;max-width:400px;padding:24px 32px}.error-box p{color:#fca5a5;margin-bottom:16px}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:background .2s}.btn-primary:hover{background:#2563eb}.logo-mark{background:linear-gradient(135deg, var(--accent), #6366f1);color:#fff;letter-spacing:-1px;border-radius:18px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:24px;font-family:Space Mono,monospace;font-size:28px;font-weight:700;display:flex}.logo-mark.small{letter-spacing:0;border-radius:10px;width:36px;height:36px;margin-bottom:0;font-size:14px}.login-page{gap:32px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;padding:48px 56px;display:flex}.brand-title{color:var(--text);letter-spacing:-.5px;margin-bottom:6px;font-family:DM Sans,sans-serif;font-size:26px;font-weight:700}.brand-dot{color:var(--accent)}.brand-sub{color:var(--text-muted);margin-bottom:32px;font-size:14px}.btn-google{color:#1f2937;cursor:pointer;background:#fff;border:none;border-radius:8px;align-items:center;gap:12px;padding:12px 28px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;transition:box-shadow .2s,transform .15s;display:flex}.btn-google:hover{transform:translateY(-1px);box-shadow:0 4px 20px #3b82f64d}.btn-google:active{transform:translateY(0)}.footer-text{color:var(--text-muted);font-size:12px}.dashboard{flex-direction:column;min-height:100vh;display:flex}.dash-header{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.header-left{align-items:center;gap:12px;display:flex}.header-brand{color:var(--text);letter-spacing:-.3px;font-family:DM Sans,sans-serif;font-size:17px;font-weight:700}.header-right{align-items:center;display:flex}.user-info{align-items:center;gap:12px;display:flex}.avatar{border:2px solid var(--border);border-radius:50%;width:36px;height:36px}.user-meta{flex-direction:column;display:flex}.user-name{color:var(--text);font-size:14px;font-weight:600;line-height:1.2}.user-role{color:var(--accent);text-transform:uppercase;letter-spacing:1px;font-family:Space Mono,monospace;font-size:11px}.dash-main{flex-direction:column;flex:1;align-items:center;padding:48px 32px;display:flex}.greeting{text-align:center;margin-bottom:48px}.greeting h1{color:var(--text);letter-spacing:-.5px;margin-bottom:8px;font-size:32px;font-weight:700}.greeting p{color:var(--text-dim);font-size:16px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;width:100%;max-width:760px;display:grid}.app-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:inherit;align-items:center;gap:16px;padding:24px;text-decoration:none;transition:all .25s;display:flex;position:relative;overflow:hidden}.app-card:before{content:"";border-radius:var(--radius);background:linear-gradient(135deg, transparent 40%, var(--card-accent) 100%);-webkit-mask-composite:xor;opacity:0;pointer-events:none;padding:1px;transition:opacity .3s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.app-card:hover:before{opacity:1}.app-card:hover{background:var(--surface-hover);transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.card-icon{background:#ffffff0a;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-size:32px;display:flex}.card-body{flex:1;min-width:0}.card-body h3{color:var(--text);margin-bottom:4px;font-size:16px;font-weight:700}.card-body p{color:var(--text-dim);font-size:13px;line-height:1.4}.card-arrow{color:var(--text-muted);flex-shrink:0;font-size:20px;transition:color .2s,transform .2s}.app-card:hover .card-arrow{color:var(--card-accent);transform:translate(4px)}.dash-footer{border-top:1px solid var(--border);justify-content:center;padding:24px;display:flex}.btn-logout{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:8px 24px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:all .2s}.btn-logout:hover{color:#ef4444;border-color:#ef4444}@media (width<=640px){.login-card{margin:0 16px;padding:36px 28px}.brand-title{font-size:22px}.dash-header{padding:12px 16px}.user-meta{display:none}.dash-main{padding:32px 16px}.greeting h1{font-size:24px}.card-grid{grid-template-columns:1fr;gap:12px}.app-card{padding:18px}}
