@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg-deep: #080e1a;--bg-base: #0c1524;--bg-surface: #12203a;--bg-elevated: #182944;--border: rgba(255, 255, 255, .07);--copper: #b46542;--copper-light: #c47e62;--copper-glow: rgba(180, 101, 66, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary);background:var(--bg-deep)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}.login-screen,.portal-screen{position:relative;min-height:100dvh;background:linear-gradient(135deg,#080e1a,#0d1b2e,#12203a)}.login-screen{display:flex;align-items:center;justify-content:center;padding:24px}.login-particles{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 30%,rgba(180,101,66,.06) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(78,184,212,.05) 0%,transparent 50%);pointer-events:none}.login-card{position:relative;z-index:1;width:min(90vw,420px);padding:48px 44px;text-align:center;background:#12203acc;border:1px solid var(--border);border-radius:20px;box-shadow:0 25px 60px #0006;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-card__glow{position:absolute;top:-1px;left:50%;width:60%;height:2px;transform:translate(-50%);background:linear-gradient(90deg,transparent,var(--copper),transparent);border-radius:2px}.login-logo{width:140px;height:auto;margin:0 auto 24px;display:block}.login-title{margin:0 0 8px;font-size:1.5rem;font-weight:800;background:linear-gradient(135deg,var(--text-primary),var(--copper-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.login-subtitle{margin:0 0 32px;color:var(--text-secondary);font-size:.9rem}.google-btn{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:14px 32px;color:#1a1a1a;background:var(--text-primary);border-radius:50px;box-shadow:0 4px 14px #0000004d;font-size:.95rem;font-weight:600;transition:transform .2s ease,box-shadow .2s ease}.google-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.login-error{display:none;margin-top:20px;padding:12px 16px;color:#ef4444;background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:.85rem;line-height:1.4}.login-error.visible{display:block}.portal-screen{padding:40px 20px}.shell{position:relative;z-index:1;width:min(1120px,100%);margin:0 auto}.header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:28px}.portal-logo{width:126px;height:auto;margin-bottom:22px}h1{margin:0;font-size:2rem;font-weight:800}p{margin:8px 0 0;color:var(--text-secondary)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.card{min-height:180px;padding:20px;display:flex;flex-direction:column;justify-content:space-between;background:#12203ad6;border:1px solid var(--border);border-radius:10px;box-shadow:0 18px 44px #0000003d}.card h2{margin:0;font-size:1.05rem;color:var(--text-primary)}.card p{color:var(--text-muted);font-size:.9rem;line-height:1.45}.actions{display:flex;gap:8px;margin-top:18px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:10px 16px;border:1px solid transparent;border-radius:8px;color:#fff;background:var(--copper);font-size:.9rem;font-weight:700;transition:background .2s ease,transform .2s ease,border-color .2s ease}.button:hover{background:var(--copper-light);transform:translateY(-1px)}.button-ghost{color:var(--text-secondary);background:var(--bg-surface);border-color:var(--border)}.button-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.spinner{width:36px;height:36px;margin:0 auto;border:3px solid var(--border);border-top-color:var(--copper);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:720px){.login-card{padding:40px 28px}.portal-screen{padding:28px 16px}.header,.actions{flex-direction:column}}
