*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #f5f5f0;--color-surface: #ffffff;--color-primary: #1a1a2e;--color-primary-light: #2d2d4e;--color-accent: #c9a96e;--color-accent-light: #e8c4a0;--color-text: #1a1a2e;--color-text-muted: #6b7280;--color-border: #e5e7eb;--color-error-bg: #fef2f2;--color-error: #dc2626;--color-success-bg: #f0fdf4;--color-success: #16a34a;--color-disabled: #9ca3af;--color-disabled-bg: #f3f4f6;--radius: 12px;--radius-sm: 8px;--shadow: 0 4px 24px rgba(0, 0, 0, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .06)}html,body,#root{height:100%}body{font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,Noto Sans JP,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(135deg,#1a1a2e,#2d2d4e,#1a1a2e)}.auth-card{background:var(--color-surface);border-radius:var(--radius);padding:40px 36px;width:100%;max-width:420px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}.auth-logo{font-size:40px;text-align:center;line-height:1}.auth-title{font-size:22px;font-weight:700;text-align:center;color:var(--color-primary)}.auth-subtitle{font-size:14px;text-align:center;color:var(--color-text-muted);margin-top:-8px}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px}.alert-error{background:var(--color-error-bg);color:var(--color-error);border:1px solid #fecaca}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid #bbf7d0}.btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s;width:100%;font-family:inherit}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-google{background:#fff;color:#1f2937;border:1px solid var(--color-border)}.btn-google:hover{background:#f9fafb}.btn-secondary{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg)}.btn-logout{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);width:auto;padding:8px 16px;font-size:13px}.btn-logout:hover{background:var(--color-error-bg);color:var(--color-error);border-color:#fecaca}.google-icon{width:18px;height:18px;flex-shrink:0}.link-btn{background:none;border:none;color:var(--color-accent);font-size:13px;cursor:pointer;text-decoration:underline;font-family:inherit;align-self:center;padding:4px}.link-btn:hover{color:var(--color-primary)}.divider{display:flex;align-items:center;gap:12px;color:var(--color-text-muted);font-size:13px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-border)}form{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--color-text)}.form-group input{padding:11px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color .15s;width:100%}.form-group input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #c9a96e26}.form-group input::placeholder{color:var(--color-disabled)}.auth-footer{font-size:13px;text-align:center;color:var(--color-text-muted)}.auth-footer a{color:var(--color-accent);text-decoration:none;font-weight:600;margin-left:4px}.auth-footer a:hover{text-decoration:underline}.pending-card{text-align:center;gap:20px}.pending-icon{font-size:56px;line-height:1}.pending-message{font-size:16px;color:var(--color-text);line-height:1.8}.pending-info{background:var(--color-bg);border-radius:var(--radius-sm);padding:16px;font-size:13px;color:var(--color-text-muted);display:flex;flex-direction:column;gap:6px}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--color-text-muted);font-size:14px}.spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg)}.dashboard-header{background:var(--color-primary);color:#fff;padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;gap:16px;position:sticky;top:0;z-index:10;box-shadow:0 2px 8px #0003}.header-brand{display:flex;align-items:center;gap:10px}.header-logo{font-size:22px}.header-title{font-size:17px;font-weight:700;letter-spacing:.02em}.header-user{display:flex;align-items:center;gap:16px}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.user-name{font-size:14px;font-weight:600}.user-role{font-size:11px;color:var(--color-accent-light);background:#ffffff1a;padding:1px 8px;border-radius:20px}.dashboard-main{flex:1;padding:32px 24px;max-width:1100px;width:100%;margin:0 auto}.dashboard-greeting{font-size:20px;font-weight:700;margin-bottom:24px;color:var(--color-primary)}.app-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.app-card{background:var(--color-surface);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow-card);position:relative;overflow:hidden;text-decoration:none;color:inherit;transition:box-shadow .2s,transform .15s}.app-card--active{cursor:pointer;border:1px solid var(--color-border)}.app-card--active:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-2px);border-color:var(--color-accent)}.app-card--disabled{cursor:default;border:1px solid var(--color-border);opacity:.6;filter:grayscale(30%)}.app-card-icon{font-size:32px;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border-radius:10px}.app-card-body{flex:1;min-width:0}.app-card-name{font-size:15px;font-weight:700;color:var(--color-text);margin-bottom:2px}.app-card-desc{font-size:12px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-card-arrow{font-size:18px;color:var(--color-accent);flex-shrink:0}.badge{position:absolute;top:10px;right:10px;font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;letter-spacing:.04em}.badge-soon{background:#e5e7eb;color:#6b7280}@media(max-width:480px){.auth-card{padding:28px 20px}.dashboard-header{padding:0 16px}.header-title,.user-info{display:none}.dashboard-main{padding:20px 16px}.app-grid{grid-template-columns:1fr}}
